概念:
重载函数调用操作符的类,其对象常称为函数对象
函数对象使用重载的()时,行为类似函数调用,也叫仿函数
本质: 函数对象(仿函数)时一个类,不是函数
谓词:
返回bool类型的仿函数称为谓词
如果operator()接受一个参数,即一元谓词
如果operator()接受两个参数,即二元谓词
函数对象使用
特点:
函数对象使用时,可以象普通函数那样调用,也可以有参数,可以有返回值
函数对象超出普通函数概念,函数对象可以有自己的状态
函数对象可以作为参数传递
//降序仿函数
class DesOrder
{
public:
void operator()(int v1,int v2)
{
return v1 > v2;
}
}
int main()
{
//set 容器降序 排序
set<int,DesOrder> setV;
setV.insert(10);
setV.insert(70);
setV.insert(20);
setV.insert(40);
for(set<int>::iterator it = setV.begin();it != setV.end();it++)
cout << *it << " ";
cout << endl;
system("pause");
return 0;
}
内建函数对象:STL 内建立的函数对象(算数仿函数、关系仿函数、逻辑仿函数)
使用时,引用 #include<functional>
算数仿函数: (实现四则运算)
template<class T>
T plus<T> //加法 T minus<T> //减法
T multiplies<T> //乘法 T drivides<T> //除法
T modulus<T> //取模 T negate<T> //取反
关系仿函数: (实现关系对比)
template<class T>
bool equal_to<T> //等于 bool not_equal_to<T> //不等于
bool greater<T> //大于 bool greater_equal<T> //大于等于
bool less<T> //小于 bool less_equal<T> //小于等于
逻辑仿函数:(实现逻辑运算)
template<class T>
bool logical_and<T> // 与 bool logical_or<T> // 或 bool logical_not<T> // 非