调用了C++对象生存期和析构函数

C++ object lifetime and destructors called

本文关键字:析构函数 生存期 对象 C++ 调用      更新时间:2023-10-16

我正在努力理解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

所以,我的问题是:

  1. 为什么在语句v[0]=bar中没有调用复制构造函数
  2. 为什么最初称为bar的对象的析构函数被调用两次(即~Foo(): 2在输出上被看到两次)

有人能帮我吗?

感谢

  1. 调用赋值运算符是因为v[0]处的对象已经构造完成。自动分配运算符将执行所有成员的浅层复制,这些成员。。。

  2. 由于自动赋值运算符的浅拷贝,由于两个对象包含值为2的成员_x,因此~Foo():2会出现两次。

v[0]=bar;调用隐式定义的复制赋值运算符Foo &operator=(const Foo &);)。它将x_(2)从bar复制到v[0]。因此,当调用barv[0]的析构函数时,可以看到2

尝试使用赋值运算符,因此2出现两次