What is the effect of call to a trivial destructor?(调用无关紧要的析构函数会有什么效果?)
问题描述
调用普通析构函数会终止对象的生命周期吗?
我读了this和this,但没有找到好的解释。这些线程声明简单的析构函数调用没有任何效果,像struct A { int x; } a; a.~A(); a.~A();这样的代码是合法的。
但我在标准中找到了这个例子:
struct C { };
void f() {
C * pc = new C;
using C2 = C;
pc->C::~C2(); // OK, destroys *pc
C().C::~C(); // undefined behavior: temporary of type C destroyed twice
using T = int;
0 .T::~T(); // OK, no effect
0.T::~T(); // error: 0.T is a user-defined-floating-point-literal (5.13.8)
}
此处C具有简单的析构函数,但C类型的对象的双重析构仍具有未定义的行为?
推荐答案
从C++20个简单的析构函数调用开始,结束对象的生命周期。在此之前,它们不执行此操作,并且多次调用析构函数是有效的。
在C++17(草案N4659)中,在[basic.life]/1.3中明确排除了琐碎的析构函数,而带有琐碎析构函数的对象将一直存在,直到它们的存储持续时间结束或其存储被重新使用([basic.life]/1.4)。
这已更改为this draft commit中的CWG issue 2256分辨率。
还要注意,在C++20中,伪析构函数调用也会结束生命周期,但在此之前不会。您在问题中链接的两个问题都讨论了这种伪析构函数调用。参见草案[diff.cpp17.basic]/1中与C++17的兼容性说明(N4861)。
这篇关于调用无关紧要的析构函数会有什么效果?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:调用无关紧要的析构函数会有什么效果?
基础教程推荐
- 初始化列表*参数*评估顺序 2021-01-01
- CString 到 char* 2021-01-01
- 我应该对 C++ 中的成员变量和函数参数使用相同的名称吗? 2021-01-01
- 非静态 const 成员,不能使用默认赋值运算符 2022-10-09
- 为什么派生模板类不能访问基模板类的标识符? 2021-01-01
- 如果我为无符号变量分配负值会发生什么? 2022-01-01
- GDB 显示调用堆栈上函数地址的当前编译二进制文 2022-09-05
- 通过引用传递 C++ 迭代器有什么问题? 2022-01-01
- 为什么 typeid.name() 使用 GCC 返回奇怪的字符以及如 2022-09-16
- 为什么 RegOpenKeyEx() 在 Vista 64 位上返回错误代码 2021-01-01
