我正在尝试理解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
中调用复制构造函数?~Foo(): 2
在输出中被看到两次?)有人能帮助我吗?
谢谢
答案 0 :(得分:4)
调用赋值运算符,因为已经构造了v [0]处的对象。自动赋值运算符将执行所有成员的浅表副本......
由于自动赋值运算符的浅副本,因为两个对象包含值为2的成员_x,所以看起来~Foo():2被看到两次。
答案 1 :(得分:1)
在v[0]=bar;
调用隐式定义的复制赋值运算符(Foo &operator=(const Foo &);
)。它会将x_
(2)从bar
复制到v[0]
。因此,当2
和bar
的析构函数被调用时,您会看到v[0]
。
答案 2 :(得分:0)
尝试使用赋值运算符,因此出现两次