仿函数的两点优势:
1.仿函数可以有状态,是smart function。
2.仿函数可能获得更好的性能,借助于template在编译器确定的细节。
#include <iostream>
#include<vector>
template <class T>
inline void PRINT_ELEMENTS(const T& coll,const char* optcstr="")
{
//typename T::const_iterator pos;
std::cout << optcstr;
for (auto pos : coll)
{
std::cout << pos << ' ';
}
std::cout << std::endl;
}
//仿函数
namespace std {
template <class Iterator,class Operation>
Operation for_each(Iterator act,Iterator end,Operation op) {
while (act != end) {
op(*act);
++act;
}
return op;
}
}
template <int theValue>
void add(int& elem){
elem += theValue;
}
class AddValue
{
public:
AddValue(int v) :theValue(v) {};
~AddValue();
void operator() (int& elem) const {
elem += theValue;
}
private:
int theValue;
};
AddValue::~AddValue()
{
}
int main()
{
std::vector<int> vec;
vec.push_back(2);
vec.push_back(3);
vec.push_back(1);
vec.push_back(55);
std::for_each(vec.begin(), vec.end(), AddValue(10));//仿函数
std::for_each(vec.begin(), vec.end(), add<20>);//模板函数
PRINT_ELEMENTS(vec);
}
本文探讨了仿函数在C++编程中的两大优势:状态保持能力与潜在的性能提升。通过实例展示了如何使用仿函数进行元素操作,比较了其与模板函数在实际应用中的差异。
834

被折叠的 条评论
为什么被折叠?



