第一种是类成员中有成员是类对象,并且该成员的类含有默认构造函数,那么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;
- }