// 比较函数的巧妙技巧:用重载了()操作符的类来代替比较函数
#include <vector>
#include <string>
#include <algorithm>
using namespace std;
#include <vector>
#include <string>
#include <algorithm>
using namespace std;
class CmpClass
{
public:
CmpClass(string strEqualValue)
{
m_strEqualValue = strEqualValue;
}
inline BOOL operator () (const string & str)
{
return str == m_strEqualValue;
}
private:
string m_strEqualValue;
};
int _tmain(int argc, _TCHAR* argv[])
{
string str1 = "str!001";
string str2 = "str!002";
vector<string> vecName;
vecName.push_back(str1);
vecName.push_back(str2);
// 在泛形算法find_if中,要求一个比较函数时,传入一个重载了()操作符的类,更方便的实现功能
// 下面的算法实现了从容器vecName中查找值为str2的项,并返回该项的迭代器
vector<string>::iterator iter = find_if(vecName.begin(), vecName.end(), CmpClass(str2));
if (iter != vecName.end())
{
printf("%s/r/n", (*iter).c_str());
}
return 0;
}