关于仿函数的应用

在使用仿函数的时候,主要用到以下两种:一种是以基类std::unary_function派生出来的派生类;另一种是以基类std::binary_function派生出来的派生类。而这两种有什么区别呢?它们之间的区别只是第一种接收的参数个数为一个,而第二种接收的参数的个数为两个。仅此而已。

好了,我们还是来几个例子看看:

第一种的使用

template<typename T>
class MeetsThreshold: public std::unary_function<Widget, bool>{
private:
const T threshold;

public:
MeetsThreshold(const T& threshold);
bool operator()(const Widget&) const;
...
};
第二种的使用

struct WidgetNameCompare:
public std::binary_function<Widget, Widget, bool>{
bool operator()(const Widget& lhs, const Widget& rhs) const;
};
注意:上面所说的接收参数的个数也就是仿函数里面的重定义函数调用操作符中的所接收的参数个数于类型,他们是相一致的。


上面是介绍stl库中的仿函数,而另外一个库中也有仿函数(Loki库),如果想详细其中的实现,可以下载Loki库来进行研究。

你在进行读Loki库中的Functor的时候,必须首先要了解那段火星代码,也就是Typelist,这个是整个泛型编程的精髓,实现了模板的完美递归。

你可能感兴趣的:(编程,function,struct,functor)