불완전한 유형에 std::unique_ptr 사용
pimpl 관용구에서 불완전한 유형에 std::unique_ptr을 사용하면 컴파일이 발생할 수 있습니다. 오류. 다음 코드를 고려해보세요.
class window { window(const rectangle& rect); private: class window_impl; // defined elsewhere std::unique_ptr<window_impl> impl_; // won't compile };
문제
이 문제는 컴파일러가 std::에 대한 할당을 결정하기 위해 불완전한 유형의 크기를 알아야 한다는 사실에서 비롯됩니다. 고유_ptr. 이 정보를 사용할 수 없어 컴파일 오류가 발생합니다.
해결책
이 문제를 해결하려면 고유_ptr을 보유하는 클래스에 대한 소멸자를 구현하는 것이 필수적입니다. 이는 컴파일러에서 생성된 기본 소멸자에는 해당 유형의 완전한 선언이 필요하기 때문입니다. 예는 다음과 같습니다.
class foo { class impl; std::unique_ptr<impl> impl_; public: foo(); // You may need a def. constructor to be defined elsewhere ~foo(); // Implement (with {}, or with = default;) where impl is complete };
소멸자를 구현함으로써 컴파일러는 Unique_ptr의 소멸을 처리하는 데 필요한 지식을 얻습니다.
특수 사례
특정 시나리오에서는 불완전한 유형과 함께 Unique_ptr을 사용하는 것이 좋지 않을 수 있습니다. 가능:
class impl; struct ptr_impl : std::unique_ptr<impl> { ~ptr_impl(); // Implement (empty body) elsewhere } impl_;
이 지침을 따르면 불완전한 유형과 함께 고유_ptr을 효과적으로 사용하여 원활한 컴파일 프로세스를 보장할 수 있습니다.
위 내용은 C에서 불완전한 유형에 `std::unique_ptr`을 어떻게 사용할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!