sort函数的定义:
void sort (RandomAccessIterator first, RandomAccessIterator last, Compare comp);前两个参数我们都比较熟悉,一般是迭代器参数分别指向要排序范围的first位置和last位置的下一个位置,第三个参数要求是一个函数指针,通过第三个参数可以让我们自定义排序规则。
类外第三个参数直接传递函数指针就可以
bool com(int a, int b){ return a > b; } int main(){ vector<int> v = {2,1,4,3,5,6,8,3,2}; sort(v.begin(), v.end(), com); for(int a : v) cout<<a<<" "; return 0; }结果:编译成功,输出如下:
//不适用第三个参数,则按照从小到大的默认输出 8 6 5 4 3 3 2 2 1类内的comp成员函数需要加上static才行,看个例子:
class Test{ public: void test(){ vector<int> v = {2,1,4,3,5,6,8,3,2}; sort(v.begin(), v.end(), comp); for(int a : v) cout<<a<<" "; } private: bool comp(int a, int b){ return a > b; } }; int main(){ Test t; t.test(); return 0; }编译报错:
error: must use '.*' or '->*' to call pointer-to-member function in '((__gnu_cxx::__ops::_Iter_comp_val<bool (Test::*)(int, int)>*)this)->__gnu_cxx::__ops::_Iter_comp_val<bool (Test::*)(int, int)>::_M_comp (...)', e.g. '(... ->* ((__gnu_cxx::__ops::_Iter_comp_val<bool (Test::*)(int, int)>*)this)->__gnu_cxx::__ops::_Iter_comp_val<bool (Test::*)(int, int)>::_M_comp) (...)' { return bool(_M_comp(*__it, __val));之所以报错其实很好理解: 成员函数都有一个默认参数:this指针,也就是说我们写的comp成员函数其实有三个参数:
bool comp(const *this, int a, int b)而我们的sort()函数要求的comp函数只接收两个参数,参数个数不匹配!!!
Lambda 表达式的基本语法如下:
[ caputrue ] ( params ) opt -> ret { body; }; capture是捕获列表;params是参数表;(选填)opt是函数选项;可以填mutable,exception,attribute(选填) mutable说明lambda表达式体内的代码可以修改被捕获的变量,并且可以访问被捕获的对象的non-const方法。 exception说明lambda表达式是否抛出异常以及何种异常。 attribute用来声明属性。ret是返回值类型(拖尾返回类型)。(选填)body是函数体。有关lambda表达式详细介绍见C++11常用新特性第7条。