常用的代码如下:
Base b;
cout<<"hello"<<endl;
结果:
基类构造 0x62fe84
hello
基类析构0x62fe84
但是这样的代码就不同了:
Base(); //匿名的临时对象
cout<<"hello"<<endl;
运行结果:
基类构造 0x62fe84
基类析构0x62fe84
hello
可见临时创建的类对象立刻销毁了,这与平时创建在stack上的对象再出了局部范围再销毁是不同的。
看这样的代码,是关于显式调用构造函数导致的成员变量未初始化问题:
#include <iostream>
class CTest
{
public:
CTest()
{
m_a = 1;
}
CTest(int b)
{
m_b = b;
CTest();
}
~CTest() {}
void showA()
{
std::cout<<"a:"<<m_a;
}
private:
int m_a;
int m_b;
};
void main()
{
CTest myTest(2);
t.showA();
}
结果是a:6487936Press
,也就是m_a未初始化。这里我们创建的对象是myTest,希望对其成员m_a初始化,但在构造函数里显式调用另一个构造函数,实际上是创建了一个临时对象,这个对象对m_a初始化了,这跟myTest是没有关系的,而且它很快又销毁了,所以没有达到目的。
这样的代码是有问题的:
Base b;
b.~Base();
cout<<"hello"<<endl;
结果是二次析构了:
基类构造 0x62fe84
基类析构 0x62fe84
hello
基类析构 0x62fe84
所以不要显式调用构造函数和析构函数,这是危险的。