비다형성 공유 포인터: 비밀 공개
Lidström 씨와 Tsirunyan 씨 사이의 열띤 논쟁은 근본적인 질문을 제기합니다. 다형성을 위해 가상 소멸자를 요구하지 않고 shared_ptr을 구현하는 것이 가능합니다. 수업?
미스터. shared_ptr
그러나 C 11 표준과 Boost 라이브러리는 그러한 실제로 구현이 가능합니다. 이 위업은 "유형 삭제" 개념을 통해 달성됩니다:
template<class T> class shared_ptr { public: ... template<class Y> explicit shared_ptr(Y* p); ... };</p> <p>제공된 예에서 shared_ptr<Base><sp(new Derived);, Y=Derived인 템플릿 생성자는 다음을 생성하고 초기화합니다. shared_ptr 객체. 결정적으로 이 생성자는 참조 카운터가 포함된 제어 블록에 대한 포인터와 Derived 클래스에 맞게 특별히 맞춤화된 삭제자 객체를 저장합니다.</p> <p>참조 횟수가 0으로 떨어지면 삭제자 객체는 파생 클래스의 구조는 할당된 메모리를 폐기하기 위해 호출됩니다.</p> <p>C 11 표준은 요구 사항에 이 동작을 명시적으로 지정합니다. 생성자:</p> <pre class="brush:php;toolbar:false">Requires: ... The expression delete p shall be well formed, shall have well defined behaviour and shall not throw exceptions. Effects: Constructs a shared_ptr object that owns the pointer p.
이렇게 하면 포인터가 Derived에서 Base로 캐스팅된 경우에도 삭제자가 적절하게 호출되고 메모리가 안전하게 해제됩니다.
마찬가지로 표준에서는 소멸자의 동작:
Effects: ... Otherwise, if *this owns a pointer p, and delete p is called.
템플릿 생성자와 유형 삭제를 활용하여 shared_ptr은 다형성 클래스의 가상 소멸자를 사용하여 더 넓은 범위의 시나리오에서 효율적인 메모리 관리를 가능하게 합니다.
위 내용은 다형성 클래스에서 `shared_ptr`이 가상 소멸자 없이 작동할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!