我可以在lambda Capture子句中声明变量吗?

Can I declare a variable inside a lambda capture clause?(我可以在lambda Capture子句中声明变量吗?)
本文介绍了我可以在lambda Capture子句中声明变量吗?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我想提交一个句柄,但我只想在共享指针仍然有效的情况下执行它:

// elsewhere in the class:
std::shared_ptr<int> node;

// later on:
const std::weak_ptr<int> slave(node); // can I do this in the capture clause somehow?
const auto hook = [=]()
{
  if (!slave.expired())
    //do something
  else
    // do nothing; the class has been destroyed!
};

someService.Submit(hook); // this will be called later, and we don't know whether the class will still be alive

我可以在lambda的Capture子句中声明slave吗?类似于const auto hook = [std::weak_ptr<int> slave = node,=]()....,但不幸的是这不起作用。我希望避免声明变量然后复制它(不是出于性能原因;我只是认为如果我可以创建lambda所需的任何内容而不污染封闭的作用域,则会更清楚、更整洁)。

推荐答案

您可以使用C++14中的通用lambda捕获来完成此操作:

const auto hook = [=, slave = std::weak_ptr<int>(node)]()
{
    ...
};

这里有一个live example。请注意,由于没有参数或显式返回类型,因此可以省略空参数列表(())。

这篇关于我可以在lambda Capture子句中声明变量吗?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

error when trying to run an overloaded function with float parameters.(尝试运行带有浮点参数的重载函数时出错。)
C++ lt;lt; operator overloading without friend function(没有友元函数的C++lt;lt;运算符重载)
C++ - How does the compiler decide between overloaded functions with reference types as parameter?(C++-编译器如何决定使用引用类型作为参数的重载函数?)
How can I invoke an overloaded () operator on the keyword this?(如何对关键字this调用重载()运算符?)
How do I denote a pure virtual function in a UML class diagram?(如何在UML类图中表示纯虚函数?)
MPI parallel IO in ASCII format (How do I do it?)(ASCII格式的MPI并行IO(我该怎么做?))