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

this 指针在 C++ 中不是“被捕获”的,而是隐式存在于每个非静态成员函数内部,指向调用该函数的那个对象。但在 lambda 表达式中,this 可以被显式或隐式地“捕获”,这和普通成员函数有本质区别。
lambda 中的 this 捕获时机:定义时确定,而非调用时
lambda 表达式在定义(即编译期/构造时)就决定了是否捕获 this,以及以什么方式捕获。一旦定义完成,其捕获列表就固定了,后续每次调用都使用同一套捕获规则。
- 写成 red">[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、怎么捕获、以及对象活多久。










