새 배치에 대한 적절한 메모리 관리
배치 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!