此代码在一个ctor中调用另一个ctor:
#include <iostream>
using namespace std;
class F {
public:
F() { cout << "ctor1\n"; }
F(int) { cout << "ctor2\n"; }
~F() { cout << "dtor\n"; }
};
class Foo {
F f;
public:
Foo() : f() { cout << "1\n"; }
Foo(int i) : f(i) { Foo(); cout << "2\n"; }
};
int main() {
Foo object(1);
return 0;
}
Run Code Online (Sandbox Code Playgroud)
结果是:
ctor2
ctor1
1
dtor
2
dtor
Run Code Online (Sandbox Code Playgroud)
看来这个成员变量f在这里被摧毁了两次,好吗?
这里
Foo(int i) { Foo(); cout << "2\n"; }
Run Code Online (Sandbox Code Playgroud)
您没有使用委托构造函数.你正在做的是Foo在构造函数体中创建一个临时实例(并立即销毁它).
委托构造函数的正确语法是
Foo(int i) : Foo() { cout << "2\n"; }
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
66 次 |
| 最近记录: |