在 C 中将唯一的 Ptr 捕获到 Lambda 表达式中
在 C 中,在处理唯一指针和 lambda 时,捕获所有权可能具有挑战性。一种常见的尝试是通过引用传递 std::unique_ptr 并在 lambda 中捕获它:
std::function<void()> getAction(std::unique_ptr<MyClass>& psomething); return [psomething]() { psomething->do_some_thing(); };
但是,由于生命周期问题,此方法无法编译。为了解决这个问题,C 14 引入了 lambda 广义捕获,它允许显式指定所有权转移:
std::function<void()> getAction(std::unique_ptr<MyClass> psomething) { return [auto psomething = move(psomething)]() { psomething->do_some_thing(); }; }
通过使用 auto psomething = move(psomething),唯一指针的所有权被转移到 lambda,从而消除生命周期问题。
但是,如果您有如图所示的自定义移动和复制实现下面:
template<typename T> T copy(const T &t) { return t; } template<typename T> T move(T &t) { return std::move(t); }
对左值引用使用 move 时应该小心,因为它可能会导致未定义的行为。例如,应避免使用 move(A()) 移动临时对象。相反,建议为左值和右值引用提供单独的移动和复制版本。
因此,当将唯一指针捕获到 lambda 表达式中时,lambda 广义捕获提供了一种方便且显式的方法来处理所有权转移,确保适当的生命周期管理。
以上是如何安全地捕获 C Lambda 表达式中的唯一指针?的详细内容。更多信息请关注PHP中文网其他相关文章!