소개:
$texttt{C }$ 프로그래밍에서 $texttt를 변환하거나 "다운캐스트"해야 하는 시나리오가 발생할 수 있습니다. 기본 클래스 $texttt{Base}$의 {unique_ptr}$를 파생 클래스 $texttt{Derived}$의 $texttt{unique_ptr}$. 이 프로세스에는 소유권 의미 체계를 유지하면서 $texttt{unique_ptr}$ 내에 저장된 원시 포인터를 원하는 파생 유형으로 캐스팅하는 작업이 포함됩니다.
해제 및 재할당을 통한 캐스팅:
질문은 $texttt{unique_ptr}$에서 객체를 해제한 다음 원시 포인터를 원하는 파생 항목으로 캐스팅하는 방법을 제안합니다. 유형. 이 접근 방식은 개념적으로는 유효하지만 잠재적인 단점이 있습니다. 객체의 수명은 일시적으로 원시 포인터에 의해 관리되며, 호출자가 나중에 $texttt{unique_ptr}$를 적절하게 처리하지 못하는 경우 메모리 누수로 이어질 수 있습니다.
대안: 정적 및 동적 고유 포인터 캐스팅:
이 문제를 해결하기 위해 다음을 활용할 수 있습니다. 다음 함수 템플릿:
구현:
template<typename Derived, typename Base, typename Del> std::unique_ptr<Derived, Del> static_unique_ptr_cast(std::unique_ptr<Base, Del>&& p) { auto d = static_cast<Derived *>(p.release()); return std::unique_ptr<Derived, Del>(d, std::move(p.get_deleter())); } template<typename Derived, typename Base, typename Del> std::unique_ptr<Derived, Del> dynamic_unique_ptr_cast(std::unique_ptr<Base, Del>&& p) { if (Derived *result = dynamic_cast<Derived *>(p.get())) { p.release(); return std::unique_ptr<Derived, Del>(result, std::move(p.get_deleter())); } return std::unique_ptr<Derived, Del>(nullptr, p.get_deleter()); }
사용:
다음 경우에 $texttt{static_unique_ptr_cast}$를 사용하세요. 파생 유형이 확실합니다. 그렇지 않으면 $texttt{dynamic_unique_ptr_cast}$를 사용하여 런타임 시 올바른 유형을 확인하세요. 이러한 함수는 원본 $texttt{unique_ptr}$에 대한 의도하지 않은 수정을 방지하기 위해 rvalue 참조를 사용합니다.
위 내용은 C에서 `unique_ptr`을 `unique_ptr`로 안전하게 다운캐스트하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!