什么是仿函數
所謂的仿函數(functor),是通過重載()運算符模擬函數形為的類。
因此,這里需要明確兩點:
1 仿函數不是函數,它是個類;
2 仿函數重載了()運算符,使得它的對你可以像函數那樣子調用(代碼的形式好像是在調用函數)。
假設有一個vector<string>,你的任務是統計長度小于20的字符串的個數,如果使用count_if函數的話,你的代碼可能長成這樣:
#define STR_LEN 20
bool LengthIsLess(const string& str) {
return str.length()<STR_LEN;
}
int res=count_if(vec.begin(), vec.end(), LengthIsLess);
其中count_if函數的第三個參數是一個函數指針,返回一個bool類型的值。
如果修改LengthIsLess這個函數原型,將原來的宏定義通過參數傳進來呢:
bool LengthIsLess(const string& str, int len)
但是他不能滿足count_if函數的參數要求:count_if要求的是僅帶有一個參數。怎么樣找到以上兩個函數的一個折中的解決方案呢?
有三種解決方案可以考慮:
1、函數的局部變量;
局部變量不能在函數調用中傳遞,而且caller無法訪問。
2、函數的參數;
這種方法我們已經討論過了&#x