C++Lambda表达式

C++Lambda表达式

定义

[capture](parameters) -> return_type { body }

部分 说明 是否可选
[capture] 捕获列表:指定如何访问外部变量 ❌ 必需(可为空 []
(parameters) 参数列表(类似函数) ✅ 可省略(无参时)
-> return_type 返回类型(通常可自动推导) ✅ 可省略
{ body } 函数体 ❌ 必需
cpp 复制代码
#include <iostream>
#include <string>
using namespace std;


int main()
{
	int a = 10, b = 20;

	// 外部变量用不着,但是也需要写[]
	// auto func1 = [](int x, int y) -> int { return x + y; };
	auto func1 = [](int x, int y) { return x + y; };
	int c = func1(a, b);
	cout << "result=" << c << endl;

	// 参数列表用不着,可以省略()
	// auto func2 = []() -> string { return "hello world"; };
	auto func2 = [] { return "hello world"; };
	cout << "result=" << func2() << endl;
}

捕获列表

捕获列表决定 Lambda 如何访问外部作用域的变量

1、按值捕获

好处就是外面修改了,里面的值不会变

cpp 复制代码
int main()
{
	int a = 10;
	auto func1 = [a]() {
		cout << "内部a=" << a << endl;
		// 不可修改,编译不过
		 // a = 100;
		};

	// 外部修改
	a = 100;
	func1();
	cout << "外部a=" << a << endl;
}

2、按引用捕获

传引用,内部、外部都可以修改,一变全变

cpp 复制代码
int main()
{
	int a = 10;
	auto func1 = [&a]() {
		cout << "内部修改前a=" << a << endl;
		// 内部修改
		a = 100;
		cout << "内部修改后a=" << a << endl;
		};

	// 外部修改
	//a = 100;
	func1();
	cout << "外部a=" << a << endl;
}

3、隐式捕获

  • [=]默认按值捕获所有用到的外部变量
  • [&]默认按引用捕获 所有用到的外部变量
    好处就是不用一个一个写参数了,默认全部参数一起带过去

按值所有

cpp 复制代码
int main()
{
	int a = 10, b = 20;
	auto func1 = [=]() {
		cout << "内部a=" << a << " ,b=" << b << endl;
		};

	// 外部修改
	a = 100;
	func1();
	cout << "外部a=" << a << " ,b=" << b << endl;
}

按引用所有

cpp 复制代码
int main()
{
	int a = 10, b = 20;
	auto func1 = [&]() {
		cout << "before内部a=" << a << " ,b=" << b << endl;
		b = 200;
		cout << "after内部a=" << a << " ,b=" << b << endl;
		};

	// 外部修改
	a = 100;
	func1();
	cout << "外部a=" << a << " ,b=" << b << endl;
}

4、混合捕获

  • [=, x] 不能在默认按值后显式按值捕获
  • [&, &x] 不能在默认按引用后显式按引用捕获
cpp 复制代码
int main()
{
	int a = 10, b = 20;
	auto func1 = [a, &b]() {
		cout << "before内部a=" << a << " ,b=" << b << endl;
		b = 200;
		cout << "after内部a=" << a << " ,b=" << b << endl;
		};

	// 外部修改
	a = 100;
	func1();
	cout << "外部a=" << a << " ,b=" << b << endl;
}
相关推荐
Molesidy12 小时前
【VSCode】【Clangd】Win下的基于LLVM/Clangd+Clangd插件+MINGW+CMake的VSCode配置C/C++开发环境的详细教程
c++·ide·vscode·clangd·llvm
报错小能手13 小时前
刷题日常 5 二叉树最大深度
算法
ᐇ95913 小时前
Java LinkedList集合全面解析:双向链表的艺术与实战
java·开发语言·链表
码银13 小时前
【数据结构】顺序表
java·开发语言·数据结构
Greedy Alg14 小时前
LeetCode 84. 柱状图中最大的矩形(困难)
算法
Mr_WangAndy14 小时前
C++_chapter13_C++并发与多线程_多线程概念,死锁,unique_lock(),lock_guard()使用
c++·lock·死锁·并发与多线程·unlock·lock_guard·unique_lock
im_AMBER14 小时前
Leetcode 52
笔记·学习·算法·leetcode
小欣加油14 小时前
leetcode 946 验证栈序列
c++·算法·leetcode·职场和发展
神仙别闹14 小时前
基于QT(C++) 实现哈夫曼压缩(多线程)
java·c++·qt