c++ - 为什么标准允许我在没有析构函数的情况下自由存储分配类?

标签 c++ c++11 c++14

如果你有一个没有析构函数的类:

struct A {
    ~A() = delete;
};

标准不允许我“本地”分配那个类的实例:

int main()
{
    A a; //error
}

但如果我在免费商店上分配它似乎没问题:

int main()
{
    a *p = new A();
}

只要我不对该指针调用 delete:

int main()
{
    a *p = new A();
    delete p; //error
}

所以我的问题是,如果我在自由存储上分配它,为什么标准允许我有一个没有析构函数的类?我想这有一些用例吗?但究竟是什么?

最佳答案

So my question is, why does the standard let me have a class without a destructor if I allocate it on free-store?

因为这不是标准功能的工作方式。

您所说的 = delete 语法是为了解决许多问题而发明的。其中之一非常具体:制作只能移动或不可移动的类型,编译器将 issue a compile-time error如果您试图调用复制(或移动)构造函数/赋值运算符。

但语法在普遍应用时还有其他用途。通过 =delete 函数,您可以防止人们调用函数的特定重载,主要是为了停止某些类型的有问题的隐式转换。如果您不调用具有特定类型的函数,则会在调用 deleted 重载时出现编译时错误。因此,=delete 可以应用于任何函数。

并且类的析构函数符合“任何函数”的条件。

该功能的设计意图不是制作不可破坏的类型。这只是在任何函数上允许 =delete 的结果。这不是设计或意图;就是这样。

虽然将 =delete 应用于析构函数没有多大用处,但让规范明确禁止它在析构函数上的使用也没有多大用处析构函数。 当然在将 =delete 应用于析构函数时表现不同并没有太大用处。

关于c++ - 为什么标准允许我在没有析构函数的情况下自由存储分配类?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36927212/

相关文章:

c++ - 使用 auto 作为参数是否有负面影响?

c++ - 从整型常量表达式转换为空指针

c++ - std::bad_cast vs NULL,有什么区别?

c++ - 在 GDI 中获取像素

c++ - 从 native C/C++ 生成并运行 LLVM 代码

c++ - 在cpp中格式化

c++ - 为什么 g++ 从带有转换运算符和不可访问的函数调用运算符的类型中初始化 std::function<> 失败?

header 或源代码中的 C++ 函数修饰符?快速引用

c++ - 这个问题中发生了运算符重载,但参数的数量和类型是相同的

c++ - 在 Visual Studio C++ 中弃用单个构造函数的正确语法是什么?