我已经声明了一个仿函数并且使用该仿函数作为参数进行了调用std :: sort。代码:
struct
{
bool operator() (const CString& item1, const CString& item2){
return MyClass::Compare( Order(_T("DESC")), item1, item2);
}
}Comparer;
std::sort(AllObjects.GetData(), AllObjects.GetData() + AllObjects.GetSize(), Comparer);
简单的问题:我能在一行中完成吗?
答案 0 :(得分:5)
如果编译器支持c++11,则可以使用lambda
std::sort(AllObjects.GetData(), AllObjects.GetData() + AllObjects.GetSize(),
[](const CString& item1, const CString& item2) {
return MyClass::Compare( Order(_T("DESC")), item1, item2);
});
没有c++11,你可以通过使用函数而不是函子来简化它
static inline bool Comparer(const CString& item1, const CString& item2) {
return MyClass::Compare(Order(_T("DESC")), item1, item2);
}
并将其用作最后一个参数。
不幸的是(?),只有一元或二元函数对象的函数包装器。如果还存在三元函数对象的包装器,那么<strong>可以执行与
类似的操作std::sort(AllObjects.GetData(), AllObjects.GetData() + AllObjects.GetSize(),
std::bind1st(std::ptr_fun(MyClass::Compare), Order(_T("DESC"))));
如果您考虑使用boost - bind,则可以尝试使用
std::sort(AllObjects.GetData(), AllObjects.GetData() + AllObjects.GetSize(),
boost::bind(MyClass::Compare, Order(_T("DESC")), _1, _2));