第一种是类成员中有成员是类对象,并且该成员的类含有默认构造函数,那么C++编译器会帮你给这个类也生成一个默认构造函数,用来调用其成员对象的构造函数,完成该成员的初始化构造。需要强调的是,如果这个成员的类也没有给出默认构造函数,那么C++编译器也不会帮你生成该类的默认构造函数。
第二种情况是这个类的基类有默认构造函数。那么C++编译器也会帮你生成该派生类的默认构造函数,以调用基类的默认构造函数,完成基类的初始化。另外还得强调一下的是,如果基类没有提供这个默认构造的函数,那么C++编译器也不会为派生类生成默认的构造函数(这里包括两层意思,第一,基类没有任何形式构造函数;第二,基类存在其他形式的非默认构造函数,当然了,这种类型就是编译不过的,道理很明显)。
第三种情况是类中存在虚函数,那么C++编译器会为你生成默认构造函数,以初始化虚表(虚函数表vftable)。
第四种情况是存在虚基类,那么C++编译器会为你生成默认构造函数,以初始化虚基类表(vbtable)。
下面的例子中,就是因为基类A中没有提供默认构造函数,导致编译无法通过,为基类A添加上默认的构造函数后,编译就通过了。。
#include "iostream"
using namespace std;
class A
{
public:
A() { } //基类添加上默认构造函数就可以了
A(int c)
{
x=c;
cout<<"A"<<endl;
}
void fun()
{
cout<<"in A fun"<<endl;
}
private:
int x;
};
class B:public A
{
public:
B(int c)
{
y=c;
cout<<"B"<<endl;
}
void fun()
{
cout<<"in B fun"<<endl;
}
private:
int y;
};
int main(void)
{
A *a=new B(2);
system("pause");
return 0;
}