我看过这个演示文稿,在幻灯片 379 上,它显示了以下代码(有一些小的改动):
#include <iostream>
using namespace std;
struct A
{
A() { cout << "A()" << endl; }
A(int v) { cout << "A(int)" << endl; }
~A() { cout << "~A()" << endl; }
};
struct X
{
X(int v) { a = v; }
X(long v) : a(v) {}
A a;
};
int main()
{
cout << "bad style:" << endl;
{ X slow(int(2)); }
cout << "good style:" << endl;
{ X fast(long(2)); }
}
输出是:
bad style:
A()
A(int)
~A()
~A()
good style:
A(int)
~A()
(这段代码在我的机器上运行,用 g++ 编译)
现在,我明白了为什么构造函数会以不好的方式被调用两次,但是为什么析构函数会这样做呢?