从函数返回 lambda 并传入引用捕获
Returning lambda from function with passed in reference capture
像
这样返回 lambda 是否安全:
auto doIt(const Object& obj) {
return [&obj]{ obj.doIt();};
}
它使用本地捕获返回 lambda,但引用是传递到函数中的引用,而不是从局部变量传递的引用。
auto doIt(const Object& obj) {
return [&obj]{ obj.doIt();};
}
这可能不是一个好主意,因为doIt(const Object& obj)
可以绑定临时对象。想象一下:
auto lm = doIt(make_object());
lm(); //Undefined behavior
这是因为临时返回的 my make_object 将在函数doIt
结束时被销毁,但您返回的 lambda 仍然包含对已销毁对象的引用。
另一个例子是:
auto func(){
Object obj = make_object();
auto lm = doIt(obj);
lm(); //This is Ok
return lm;
}
void something{
auto val = func();
val(); //Undefined Behavior
}
编辑:请参阅评论。
您可以添加void doIt(const Object&&) = delete;
重载以防止临时重载;由@StoryTeller提供。
相关文章:
- C++有什么方法可以在既不调用函数模板也不提供其模板参数的情况下引用函数模板?
- 无法将右值引用函数与 GCC 匹配
- C ++引用函数参数似乎包含原始对象的副本,而不是充当"real reference"
- 通过引用函数传递指针参数是什么意思?
- 常量引用函数参数的地址何时唯一?
- 我想了解为什么在这个例子中使用引用函数?或者引用在c++函数中的重要性
- C++ 通过引用函数传递数组,但内容保持不变
- 用数组或指针引用函数?
- 引用函数如何"int &foo();"工作?
- 常量引用函数参数:是否可以禁止临时对象?
- 计算在代码中引用函数的次数
- <initializer_list> 引用函数
- 字符串引用(函数)的差异
- 在类中引用函数时的"No Matching Function for Call"
- 无法通过引用函数"calcValues"中"firstNum"和"secondNum"变量来更改值
- 尝试引用已删除的函数(不引用函数)
- 引用函数指针
- 引用函数按值和自动返回
- 为什么我们可以取消引用函数指针
- 通过引用函数传递值的目的是什么