> 백엔드 개발 > C++ > 다형성 클래스에서 `shared_ptr`이 가상 소멸자 없이 작동할 수 있나요?

다형성 클래스에서 `shared_ptr`이 가상 소멸자 없이 작동할 수 있나요?

Patricia Arquette
풀어 주다: 2024-12-06 06:44:12
원래의
280명이 탐색했습니다.

Can `shared_ptr` Work Without Virtual Destructors in Polymorphic Classes?

비다형성 공유 ​​포인터: 비밀 공개

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿