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]处的对象已经构造完成。自动赋值运算符将执行所有成员的浅表复制...
由于自动赋值运算符的浅拷贝,~Foo(): 2 会出现两次,因为两个对象都包含值为 2 的成员 _x。
在 v[0]=bar;
处调用隐式定义的 复制赋值运算符 (Foo &operator=(const Foo &);
)。它将 x_
(2) 从 bar
复制到 v[0]
。因此,当调用 bar
和 v[0]
的析构函数时,您会看到 2
。
尝试使用赋值运算符,因此 2 出现两次
我正在尝试了解 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]处的对象已经构造完成。自动赋值运算符将执行所有成员的浅表复制...
由于自动赋值运算符的浅拷贝,~Foo(): 2 会出现两次,因为两个对象都包含值为 2 的成员 _x。
在 v[0]=bar;
处调用隐式定义的 复制赋值运算符 (Foo &operator=(const Foo &);
)。它将 x_
(2) 从 bar
复制到 v[0]
。因此,当调用 bar
和 v[0]
的析构函数时,您会看到 2
。
尝试使用赋值运算符,因此 2 出现两次