在关于 std::sort 的文章中,为了实现自定义排序,使用了Lambda表达式,那么Lambda是什么呢?
Lambda 是什么
简单来说:Lambda 表达式就是一个没有名字的“临时函数”或“匿名函数”。
当需要一个简单的函数逻辑时,无需离开当前的代码上下文去别处完整地定义一个函数,而是可以直接在需要它的地方,就地编写这个逻辑。用完即丢,代码清晰又紧凑。
Lambda 语法
Lambda 的语法看起来可能有点奇怪:[](){}。拆开来看,会发现它其实非常直观,而且与普通函数高度相似。
一个基本的 Lambda 表达式由三部分组成:
-
[]- 捕获列表 (Capture Clause)- 入门用法:对于基础用法而言,现在完全不需要关心它的作用,只需要记住直接写一个空的
[]即可。
- 入门用法:对于基础用法而言,现在完全不需要关心它的作用,只需要记住直接写一个空的
-
()- 参数列表 (Parameter List)- 作用:这部分和普通函数的参数列表一模一样。需要在这里定义这个临时函数接受哪些参数。
- 示例:对于
sort的比较函数,需要两个参数,所以这里就是(int a, int b)。
-
{}- 函数体 (Function Body)- 作用:这部分也和普通函数的函数体一模一样。所有的逻辑,包括
return语句,都写在这里。 - 示例:对于降序排序,函数体就是
{ return a > b; }。
- 作用:这部分也和普通函数的函数体一模一样。所有的逻辑,包括
把三者合在一起,[](int a, int b) { return a > b; } 就是一个完整的、可以实现降序比较的 Lambda 表达式。
Lambda 的使用
场景一:替代简单的命名函数
使用命名函数 (旧方法)
// 1. 在别处定义一个函数
bool compare_desc(int a, int b) {
return a > b;
}
int main() {
std::vector<int> numbers = {5, 7, 4, 2, 8};
// 2. 在 sort 中调用它
std::sort(numbers.begin(), numbers.end(), compare_desc);
}
使用 Lambda 表达式 (现代 C++ 方法)
int main() {
std::vector<int> numbers = {5, 7, 4, 2, 8};
// 直接将函数逻辑嵌入到 sort 的调用中!
std::sort(numbers.begin(), numbers.end(), [](int a, int b) {
return a > b;
});
}
对比优势:代码的逻辑不再被分割。读到 sort 这一行时,排序规则一目了然,极大地增强了代码的可读性。
场景二:处理自定义结构体
struct Student {
std::string name;
int score;
};
int main() {
std::vector<Student> students = {
{"张三", 95}, {"李四", 88}, {"王五", 100}
};
// 按分数从高到低排序,逻辑非常清晰
std::sort(students.begin(), students.end(), [](const Student& a, const Student& b) {
return a.score > b.score;
});
}
总结
- Lambda 是什么? 一个没有名字的临时函数。
- 基本语法?
[](){}分别代表 捕获列表、参数列表 和 函数体。 - 为何使用? 让代码更紧凑、可读性更高。
- 如何开始? 当作普通函数的快捷写法来练习,暂时只需使用空的捕获列表
[]。

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



