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

所以,我的问题是:

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

有人能帮帮我吗?

谢谢

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

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

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

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