您好,登錄后才能下訂單哦!
C++中mem_fun 和 mem_fun_ref 如何使用,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
假設我們有以下的一個類:
class A {
public:
A(int x=0): val(x) {}
void print() { cout << val << " "; }
private:
int val;
};
另外有一個包含 class A 對象的數組: vector<A> vec;
如何對每一個類的對象調用成員函數print.
做法1: 利用下標
for(int i=0; i<vec.size(); ++i) {
vec[i].print();
}
做法2:利用迭代器
for(vector<int>::const_iterator it=vec.begin(); it!=vec.end(); ++it) {
it->print();
}
做法3:C++11強大的 auto
for(auto x : vec) {
x.print();
}
有了C++11以后,做法3其實代碼已經非常短了,但是 effective STL 中的一個條款告訴我們,
用STL的算法優先于自己手寫的循環。。比方說,這個問題就可以采用 for_each。。
原因如下:1. 效率: 算法通常比程序自己寫的循環效率更高(STL庫作者更加了解容器的底層實現,可以進行優化)
2. 正確性: 自己寫循環更容易出錯(代碼越少,越不容易出錯)
3. 可維護性:使用算法更為簡潔明了
做法4: 采用for_each
但是下面的代碼是否正確呢??
for_each(vec.begin(), vec.end(), &A::print); //無法通過編譯
編譯出錯,因為 print 是成員函數。。如果是普通的函數則沒有問題。。
for_each(vec.begin(), vec.end(), mem_fun_ref(&A::print));
如果是 vector<A*> 的話,就用 mem_fun即可。。
其實 mem_fun 和 mem_fun_ref 是兩個模板函數,返回一個函數對象(包含上述的成員函數)。。
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。