this指针在lambda中显式或隐式捕获,定义时确定方式;[this]按值捕获指针,不延长对象生命周期,悬空解引用导致未定义行为;[=]或[&]自动包含this;安全起见应优先使用shared_from_this()。

this 指针在 C++ 中不是“被捕获”的,而是隐式存在于每个非静态成员函数内部,指向调用该函数的那个对象。但在 lambda 表达式中,this 可以被显式或隐式地“捕获”,这和普通成员函数有本质区别。
lambda 中的 this 捕获时机:定义时确定,而非调用时
lambda 表达式在定义(即编译期/构造时)就决定了是否捕获 this,以及以什么方式捕获。一旦定义完成,其捕获列表就固定了,后续每次调用都使用同一套捕获规则。
写成 [this]:显式按值捕获当前对象的 this 指针(即复制一份指针值) 写成 [=] 或 [&]:根据捕获模式自动决定是否包含 this C++17 起,[=, *this] 可显式按值捕获整个对象(拷贝副本),而非仅指针
[this] 捕获的本质是捕获指针值,不是对象本身
[this] 实际上把当前成员函数调用时的 this 指针(比如 0x7fffabcd1234)作为常量存进 lambda 的闭包类型中。它不延长对象生命周期,也不阻止对象被析构。
如果 lambda 在对象销毁后被调用,this 就变成悬空指针,解引用会触发未定义行为 它和捕获局部变量不同——捕获的是指针,不是对象;没有拷贝或移动对象本身 在 lambda 内部,可直接访问 memberVar、调用 memberFunc(),语法上就像在成员函数里一样
隐式捕获 [=] 和 [&] 对 this 的处理规则
当使用默认捕获时,C++ 标准规定:只要 lambda 出现在非静态成员函数内部,且使用了类的任何成员(变量或函数),[=] 或 [&] 就会自动把 this 纳入捕获列表。
立即学习“C++免费学习笔记(深入)”;
[=] → 自动等价于 [=, this](按值捕获 this 指针) [&] → 自动等价于 [&, this](按引用捕获 this 指针,仍是传指针,但语义上表示“通过 this 访问当前对象”) 若 lambda 体内没用到任何成员,则 [=] 不会捕获 this(哪怕你在成员函数里定义它)
安全建议:避免裸 this 捕获,优先考虑弱引用或 shared_ptr
裸 [this] 最大风险是悬挂——尤其 lambda 被异步执行或存储到别处时。
若需延长对象生命周期,改用 [ptr = shared_from_this()](要求类继承自 enable_shared_from_this) 若只读且确定生命周期可控,[this] 简洁有效 对 const 成员函数,lambda 内部 this 类型为 const X*,不能修改成员(除非 mutable 或 mutable 成员)
基本上就这些。this 在 lambda 里不是魔法,它只是个被复制的指针——关键在你什么时候定义 lambda、怎么捕获、以及对象活多久。
以上就是c++++中的this指针是什么时候捕获的_c++ lambda中的this捕获详解【C++11】的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1489260.html
微信扫一扫
支付宝扫一扫