Lambda表达式的传参

Lambda表达式的传参

一直都是老实的用Lambda表达式,比如函数中以std::function func为参数,可以:

声明:void Test(int d,std::function<int(int)> func );

调用:Test(d,[](int d)->int{…..;return 0;});

在实际工程里调用:func(30);

也知道可以通过ref实现引用传参,但是其实是一直没有想清楚这个使用的情况,当然也不想想,因为觉得太简单了,今天终于弄了一把:

有一个类似于函数指针的存储的队列,需要如下方式来提交:

std::future<void>fh = executor.commit([](Data*p)->void{ std::cout <<"hello, h !"<<p->d+1<< std::endl; },p);

这个提交的函数使用的Lambda表达式,其中要传递一个数据的指针,方便在执行的时候儿处理它,那么就应用到参数的传递,因为是指针,引用不引用就无所谓了。

这时候儿才仔细的琢磨了一下,相对于回调函数,理论上讲传参是不太现实的。但是在Lambda表达式这里就可以,本身这个示例Lambda表达式也是充当回调使用的,但应用了参数后,就可来回调用(又可以回调,也可以正向传递参数),还是方便的紧。

小的细节不是不会用,也不是想不到,就是觉得它无所谓。没有在实际的应用场景用,就体会不到他的好处。其实还是没有认真的学习,认真的写一遍。

想当然,其实是很害人的。

### C++11 Lambda表达式的三种传参方式 #### 按值传递 按值传递意味着当定义lambda表达式时,捕获列表中的变量会被复制一份副本。这意味着如果后续改变了原变量的值,不会影响到lambda表达式内的那份拷贝。例如,在创建lambda之后修改了`v1`的值并不会改变lambda内部使用的那个已经保存下来的`v1`的值[^1]。 ```cpp int value = 10; auto byValue = [value]() { return value * 2; }; // 修改原始变量不影响已捕捉的值 value = 20; std::cout << "By Value Result: " << byValue() << std::endl; // 输出应为20而非40 ``` #### 按引用传递 相比之下,按引用传递允许lambda表达式直接操作外部作用域里的实际对象。任何对这些被捕获变量的操作都会反映在外围环境中。一旦某个被引用捕获的变量在其生命周期内发生变化,则这种变化也会体现在lambda体内调用此变量的结果上。 ```cpp size_t refVal = 42; auto byRef = [&refVal]() -> size_t { ++refVal; return refVal; }; byRef(); std::cout << "Reference Capture After Increment: " << refVal << std::endl; // 应输出43 ``` #### 默认捕获 默认捕获指的是使用`=`或`&`作为捕获列表的一部分来指示编译器自动决定如何捕获所有局部变量。使用`=`,则所有的本地变量都将按照值的方式被捕获;而使用`&`表示所有未特别指出名称的变量都将以引用形式被捕获。此外,默认情况下并不包括`this`指针在内的类成员变量,除非显式声明或者通过`*this`的形式将其加入捕获列表中[^2]。 ```cpp class ExampleClass { public: int memberVar; void exampleMethod(int localVar) { auto implicitCapture = [=]() mutable { // 所有局部变量均按值捕获 return localVar + this->memberVar; // 需要显式捕获 'this' }; auto explicitThis = [&, this]() { // 显式捕获所有局部变量及'this'指针 return localVar + this->memberVar; }; } }; ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值