c++ - 在静态变量定义中捕获的引用

标签 c++ c++11

#include <iostream>

void foo(int k) {
    static auto bar = [&]{
        std::cout << k << std::endl;
    };
    bar();
}

int main () {
    foo(1); foo(2); foo(3); // output is correct: 1, 2, 3
}

检查函数 foo,以及静态 lambda 如何通过引用捕获 k。这似乎可行,并且对于更复杂的数据类型而不是 int 也会发生同样的情况。

这是预期的吗? 是否可以保证每次调用 fook 的地址都相同,或者这个 UB

在此先感谢,如果之前有人回答过这个问题(我确实试图找到类似的问题但没有成功)

最佳答案

这是未定义的行为

根据 C++11 标准第 5.2.2/4 段关于函数调用表达式及其参数的初始化:

[...] The lifetime of a parameter ends when the function in which it is defined returns. The initialization and destruction of each parameter occurs within the context of the calling function. [...]

因此,您的 lambda 将存储一个引用,该引用在函数调用返回后立即变为悬空。

在这种情况下,实现可以自由(并且很可能)在每个函数调用的相同地址创建函数参数,这可能是您观察到预期输出的原因。

但是,此行为不是标准强制要求的 - 因此,您不应依赖它(如果是这种情况,您的代码将因 3.8/7 而合法)。

关于c++ - 在静态变量定义中捕获的引用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16071154/

相关文章:

c++ - 如何在 C++ 中使用 ffmpeg 获取 DirectShow 设备列表?

c++ - 在 Visual Studio 中放置并插入 unordered_map?

c++ - gcc c++11 对用户定义的常量和模板参数包的限制

c++ - 列表 vector 的正确构造函数是什么

c++ - 处理具有不同类型参数的 std::basic_string<>

c++ - 如何正确删除模板函数中的代码重复

c++ - 了解 std::move 和 unique_ptr

c++ - 在 Visual Studio 中使用命令行参数进行调试

c++ - POCO HTTPS 请求验证服务器证书

c++ - return 语句中可以省略 return 关键字吗?