当我们编写一个lambda后,编译器将表达式翻译成一个未命名类的未命名对象。在lambda表达式产生的类中含有一个重载的函数调用运算符,例如对于我们传递给stable_sort作为最后一个实参的lambda表达式来说:
vector<string> words;
// 其它代码
// 根据单的长度对其进行排序,对于长度相同的单词按照字母顺序排序
stable_sort(words.begin(), words.end(),
[](const string &a, const string &b)
{return a.size() < b.size();});
其行为类似于下面这个类的一个未命名对象
class ShorterString {
public:
bool operator() (const string &a, const string &b) const{
return a.size() < b.size();
}
};
产生的类只有一个函数调用运算符成员,它负责接受两个string并比较它们的长度,它的形参列表和函数列体与lambda表达式完成一样。用这个类替代lambda表达式后:
stable_sort(words.begin(), words.end(), ShorterString());
第三个实 参是新构建的ShorterString对象,当stable_sort内部的代码每次比较两个string时就会“调用”这一对象,此时该对象将调用运算符的函数体。