首页 >后端开发 >C++ >什么时候手动调用析构函数是合法的做法?

什么时候手动调用析构函数是合法的做法?

Susan Sarandon
Susan Sarandon原创
2024-11-22 10:13:09975浏览

When is Manually Calling a Destructor a Legitimate Practice?

什么时候手动调用析构函数是合理的?

手动调用析构函数表明存在缺陷的设计这一概念经常被断言。然而,这就引出了一个问题:这条规则有例外吗?

反例:需要手动调用析构函数的情况

确实,在某些情况下这是必要的显式调用析构函数:

1.受控内存释放:

当内存分配和释放独立于对象构造和销毁进行管理时,手动析构函数调用变得至关重要。在这种情况下,对象构造是通过在现有内存缓冲区上放置 new 来进行的,而销毁是通过显式析构函数调用来进行的。

char buffer[sizeof(MyClass)];

{
     MyClass* p = new(buffer)MyClass;
     p->dosomething();
     p->~MyClass();
}

2.特定内存分配器:

另一个例子是 std::vector 对默认 std::allocator 的使用。这里,元素是在push_back操作期间构造的,但是内存分配发生在元素构造之前的块中。因此,vector::erase 必须销毁元素,而不必重新分配内存,特别是在即将进行进一步的 push_backs 的情况下。

含义:

手动调用析构函数可能违反严格的OOP 原则模糊了对象和内存管理之间的界限。然而,在低级编程或内存分配和释放解耦的场景中,它可能是合适的。

此外,虽然随机手动析构函数调用可以指示设计问题,但它在专用类中的本地化使用可以是被认为是良好的实践。

以上是什么时候手动调用析构函数是合法的做法?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn