调用了C++对象生存期和析构函数
C++ object lifetime and destructors called
我正在努力理解C++中的对象生存期。当我运行代码时:
class Foo
{
public:
Foo();
Foo(const Foo &old);
~Foo();
int x_;
};
int nextX = 0;
Foo::Foo()
{
cout << "Foo(): " << (x_ = nextX++) << endl;
}
Foo::Foo(const Foo &old)
{
cout << "Foo(const Foo &old): " << (x_ = nextX++) << endl;
}
Foo::~Foo()
{
cout << "~Foo(): "<< x_ << endl;
}
int main()
{
Foo foo;
cout << "-----------------" << endl;
vector<Foo> v(1);
cout << "-----------------" << endl;
Foo bar;
cout << "-----------------" << endl;
v[0]=bar;
cout << "-----------------" << endl;
return 0;
}
我得到以下输出:
Foo(): 0
-----------------
Foo(): 1
-----------------
Foo(): 2
-----------------
-----------------
~Foo(): 2
~Foo(): 2
~Foo(): 0
所以,我的问题是:
- 为什么在语句
v[0]=bar
中没有调用复制构造函数 - 为什么最初称为bar的对象的析构函数被调用两次(即
~Foo(): 2
在输出上被看到两次)
有人能帮我吗?
感谢
-
调用赋值运算符是因为v[0]处的对象已经构造完成。自动分配运算符将执行所有成员的浅层复制,这些成员。。。
-
由于自动赋值运算符的浅拷贝,由于两个对象包含值为2的成员_x,因此~Foo():2会出现两次。
在v[0]=bar;
调用隐式定义的复制赋值运算符(Foo &operator=(const Foo &);
)。它将x_
(2)从bar
复制到v[0]
。因此,当调用bar
和v[0]
的析构函数时,可以看到2
。
尝试使用赋值运算符,因此2出现两次
相关文章:
- 什么时候调用组成单元对象的析构函数
- 如果C++类在类方法中具有动态分配,但没有构造函数/析构函数或任何非静态成员,那么它仍然是POD类型吗
- 内联映射初始化的动态atexit析构函数崩溃
- 什么时候调用析构函数
- 优先顺序:智能指针和类析构函数
- C++-明确何时以及如何调用析构函数
- 使用基类指针创建对象时,缺少派生类析构函数
- 在c++中使用向量时,如何调用构造函数和析构函数
- 重载运算符new[]的行为取决于析构函数
- 我需要知道编译器如何在cpp中使用析构函数
- 为什么在使用转换构造函数赋值后调用C++类的析构函数?
- 析构函数调用
- 通过引用传递-为什么要调用这个析构函数
- 对具有动态分配的内存和析构函数的类对象的引用
- 重载 -> shared_ptr 个实例中的箭头运算符<interface>,接口中没有纯虚拟析构函数
- C++成员的析构函数顺序与shared_ptr
- C++ 防止在映射中放置()时调用析构函数
- 为什么临时的生存期延长会导致析构函数被多次调用
- 在不调用析构函数的情况下结束STL容器的生存期
- 调用了C++对象生存期和析构函数