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

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

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-16 11:45:11134검색

Can shared_ptr Work Without Polymorphic Class Virtual Destructors?

다형성 클래스 가상 소멸자를 사용하지 않는 Shared_Ptr 구현

shared_ptr 구현을 위한 가상 소멸자의 필요성에 관해 Armen Tsirunyan과 Daniel Lidström 사이의 논쟁에서, 그러한 것을 요구하지 않는 shared_ptr을 디자인하는 것은 실제로 가능합니다

기술적 구현

이 구현의 핵심은 유형 삭제에 있습니다. Shared_ptr은 참조 카운터뿐만 아니라 동일한 메모리 블록에 저장된 삭제자 개체도 관리합니다. 이 삭제자의 유형은 shared_ptr의 유형과 구별되므로 다양한 동적 유형을 사용하여 객체를 유연하게 관리할 수 있습니다.

템플릿 생성자가 도입되었습니다.

template<class T>
class shared_ptr
{
public:
   ...
   template<class Y>
   explicit shared_ptr(Y* p);
   ...
};

파생 클래스의 포인터(예: shared_ptr sp(new Derived)), Y=Derived인 템플릿 생성자는 다음과 같습니다. 호출되었습니다. 이 생성자는 Derived 클래스에 대한 특정 지식을 사용하여 삭제자 개체를 만듭니다. 참조 횟수가 0에 도달하면 이 삭제자는 기본 클래스에 가상 소멸자가 없어도 파생 인스턴스를 안전하게 삭제하는 데 사용됩니다.

C 11 표준 요구 사항

C 11 표준은 이 생성자에 대한 요구 사항을 명시적으로 정의합니다.

  • 포인터 p는 다음으로 변환 가능해야 합니다. T*와 Y는 완전한 유형이어야 합니다.
  • "delete p"라는 표현식은 올바른 형식이어야 하고 동작이 잘 정의되어 있어야 하며 예외를 발생시키지 않아야 합니다.

소멸자:

  • shared_ptr이 비어 있거나 소유권을 공유하는 경우 측면이 없습니다. 효과.
  • shared_ptr이 삭제자 d가 있는 객체를 소유하면 d(p)가 호출됩니다.
  • 그렇지 않고 shared_ptr이 포인터 p를 소유하면 "delete p"가 호출됩니다.

따라서 shared_ptr 구현은 유형 삭제를 활용하고 삭제자를 주의 깊게 관리하여 객체를 효과적으로 폐기합니다. 다형성 클래스에 가상 소멸자가 필요하지 않은 경우에도 다양한 동적 유형을 사용할 수 있습니다.

위 내용은 다형성 클래스 가상 소멸자 없이 shared_ptr이 작동할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.