> 백엔드 개발 > C++ > 새로운 배치: 메모리 할당을 해제하기 위해 `delete`를 사용할 수 없는 이유는 무엇입니까?

새로운 배치: 메모리 할당을 해제하기 위해 `delete`를 사용할 수 없는 이유는 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2024-10-26 13:50:02
원래의
437명이 탐색했습니다.

 Placement New: Why Can't We Use `delete` to Deallocate Memory?

새 배치에 대한 적절한 메모리 관리

배치 new를 사용할 때 수동으로 소멸자를 호출하고 할당된 메모리를 해제하는 것은 프로그래머의 책임입니다. . 이는 일반적으로 두 작업을 모두 처리하는 삭제 연산자의 기본 동작과 다릅니다.

삭제하지 않는 이유

제공된 코드:

char* pMemory = new char[sizeof(MyClass)];
MyClass* pMyClass = new(pMemory) MyClass();
로그인 후 복사

메모리는 MyClass 객체에 해당하는 크기의 문자 배열에 대해 new[]를 사용하여 수동으로 할당됩니다. 그런 다음 배치 new를 사용하여 이 메모리 내에 객체를 구성합니다.

여기서 delete를 사용하는 것은 new[] 연산자를 사용하여 메모리를 수동으로 할당했기 때문에 올바르지 않습니다. delete는 new 연산자를 사용하여 할당된 메모리를 위한 것이지만 여기서는 그렇지 않습니다.

소멸자의 책임

new 배치가 사용되었으므로 호출하는 것은 프로그래머의 책임입니다. 객체를 해제하는 소멸자. 그러나 할당된 메모리가 자동으로 해제되지는 않습니다. 메모리 누수를 방지하려면 소멸자가 호출된 후 메모리를 명시적으로 해제해야 합니다.

내부 버퍼를 사용하는 새 배치

내부 버퍼와 함께 새 배치를 사용할 수도 있습니다. new 연산자로 할당되지 않은 것입니다. 이러한 경우 예기치 않은 동작이나 메모리 손상이 발생할 수 있으므로 연산자 삭제를 호출해서는 안 됩니다.

예:

struct buffer_struct {
    std::aligned_storage_t<sizeof(MyClass), alignof(MyClass)> buffer;
};

MyClass* pMyClass = new (&a.buffer) MyClass(); //created inside buffer_struct a
로그인 후 복사

이 경우 buffer_struct는 MyClass 객체이지만 객체 생성과 소멸은 각각 배치 new와 소멸자를 사용하여 독립적으로 처리됩니다.

위 내용은 새로운 배치: 메모리 할당을 해제하기 위해 `delete`를 사용할 수 없는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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