C++中仿函数的应用
在利用仿函数的时候,主要用到以下两种:一种是以基类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,这个是整个泛型编程的精华,实现了模板的完美递归。