在单个语句中将类类型分配给该类的取消引用指针时执行哪些操作
What operations are performed when a class type is assigned to a de-referenced pointer of that class, in a single statement?
示例:
假设我们有一个 Node 类,其中包含所有这些复制 ctor、赋值运算符和默认 ctor 重载。
现在,当我们有以下赋值时,将以什么顺序调用哪些构造函数或运算符:
Node myNode = *(new Node());
new Node()
- 创建一个新的动态分配的Node
对象。生成指向新Node
的指针。
*
- 给定一个指针,产生它指向的东西(作为左值)。
Node myNode =
- 创建一个新Node
,它是一个局部变量,并将=
右侧的任何内容传递给其构造函数。
总体效果:创建一个新的局部变量Node
,创建一个动态分配的Node
,并将动态变量复制到局部变量。此外,您无法销毁动态的,因此这会导致内存泄漏。
-
Node
'调用默认构造函数来构造匿名Node
对象。 -
Node
的复制构造函数被调用来复制初始化myNode
。 - 您泄漏了 1
Node
的内存,因为new
返回的指针在语句结束时立即超出范围。 因此,您永远无法delete
您new
编辑的Node
。
不会调用Node::operator=
,因为您正在执行使用复制构造函数的复制初始化。 像这样:
Node myNode;
myNode = Node();
将调用Node::operator=
而不是复制构造函数,因为您将在构造myNode
后分配给它。
相关文章:
- 如何使用基类指针引用派生类成员
- 将常量指针引用绑定到非常量指针
- 如果非动态变量被指针引用,何时超出范围?
- 转换指针引用的字符串
- 指针引用的生存期(以 C++为单位)
- 从 unique_ptr::get 发送指针作为指针引用进入函数
- 指针/引用的 CLion 格式
- 使用模板专用化来比较指针引用
- 如何保存指向抽象基类的指针/引用,但在 c++ 中仍然可以复制
- C++初始化指针/引用/复制细微差别
- 用数组或指针引用函数?
- 指针范围问题和返回类中封装的指针向量内的指针引用
- 强制转换为指针引用是否会导致未定义的行为
- 访问由 void 指针引用的结构的成员
- C 为什么当先前的步骤引发异常时,std :: shared_ptr的指针引用会被破坏
- 动态指针引用数组由三元运算符返回值,但有异常
- 悬空指向 int 和 char* 常量的指针/引用
- C++ 二维数组和指针引用
- 通过使用指针/引用,在C++中使用向量加快计算速度
- C++非类型模板模板到函数指针/引用