C 11에서 람다의 변수 캡처는 일반적으로 참조로 수행됩니다. 이 참조는 람다가 존재하는 한 계속 유지되며, 이로 인해 캡처된 변수가 이동되면 의도하지 않은 동작이 발생할 수 있습니다.
C 14에서는 일반화된 람다 캡처가 도입되어 이동 캡처가 가능해졌습니다. 이를 통해 고유 포인터와 같은 이동 전용 유형을 편리하게 조작할 수 있습니다.
std::make_unique<int>() .then([u = std::move(u)] { do_something_with(u); });
C 14 이전에는 도우미 기능을 사용하여 이동 캡처를 에뮬레이트할 수 있습니다.
이 접근 방식은 래퍼 클래스를 생성합니다. 값을 캡슐화하고 수명을 관리하는 rref_impl.
template <typename T> using rref_impl = ...; auto rref = make_rref(std::move(val)); [rref]() mutable { std::move(rref.get()); };
그러나 람다에서 rref를 캡처하면 복사가 가능해 잠재적으로 런타임 오류가 발생할 수 있습니다.
이 메서드는 캡처된 값을 참조로 가져와 캡처된 값으로 함수를 호출하는 람다를 반환하는 함수를 사용합니다.
template <typename T, typename F> using capture_impl = ...; auto lambda = capture(std::move(val), [](auto&& v) { return std::forward<decltype(v)>(v); });
이렇게 하면 람다 복사가 방지되고 캡처된 값이 람다 범위로 이동됩니다.
이러한 해결 방법은 일반화된 람다 캡처만큼 우아하지 않다는 점을 기억하세요. C 14에서는 이전 버전의 언어에서 이동 캡처를 에뮬레이션하는 방법을 제공합니다.
위 내용은 C Lambdas, 특히 C 11에서 이동 캡처를 어떻게 달성할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!