总结:
1.当你编写的空类被C++编译处理过后,如果你没有声明,则编译器会为空类声明:①默认构造函数②默认拷贝构造函数③赋值运算符重载函数④默认析构函数,这些函数都是public而且是inline,且默认的析构函数是非virtual的注意:唯有当这些函数需要被调用的时候,他们才会被编译器创建出来。
注意:对于如果你不写默认构造函数,编译器就会为你生成默认构造函数这种说法是错误的!上面也说了唯有被调用的时候才会创建。
什么时候才会被调用使系统合成默认构造函数呢?
这里先说一下什么是默认构造函数,注意区别自己写的默认构造函数和编译器合成的默认构造函数
详见:https://www.cnblogs.com/gklovexixi/p/5814626.html
条件1:类中含有其他类对象,且这个其他类中有默认构造函数的时候,因为需要调用默认构造函数来调用类成员的默认构造函数,这个时候编译器会为你的类合成默认的构造函数,但是这个构造函数只是用来调用类成员的默认构造函数,而不初始化你的类中的成员变量。代码如下:
class A
{
public:
A()
{
cout << "A()::" << endl;
}
};
class B
{
public:
A sa;
int _b;
};
int main()
{
B s;
cout <<"_b=" <<s._b<< endl;
system("pause");
return 0;
}
条件2:基类带有默认构造函数的派生类
因为派生类需要合成一个默认构造函数,来调用基类的构造函数,因为派生类被和成时需要显示的调用基类默认构造函数
class Base
{
public:
Base()
{
cout << "A()::" << endl;
}
};
class Derived:public Base
{
public:
int _b;
};
int main()
{
Derived s;
cout <<"_b=" <<s._b<< endl;
system("pause");
return 0;
}
条件3:带有虚函数的类:这个类可以是单独自身声明了虚函数,也可以是从基类继承而来的虚函数
因为有虚函数的类,类的每个对象会有一个虚表指针(vptr,指向虚函数表),而这个虚表指针的初始化需要构造函数来完成,以保证虚函数机制的正常运行,所以编译器会合成默认构造函数来完成此项工作。
条件4:虚继承的类,因为类对象中含有指向虚指针,也需要用构造函数初始化。
2.对于赋值运算符重载函数需要注意的是他有一定的 条件限制,万一有几个条件不满足,编译器是拒绝产生默认赋值运算符重载函数的
class Test
{
private:
string& s;
const int _x;
};
比如上面这种情况,编译器就拒绝产生赋值运算符重载函数,或者将在继承体系中将基类的赋值运算符重载声明为private,编译器同样会拒绝为其派生类生成赋值运算符重载。
3.默认拷贝构造函数和赋值运算符重载知识单纯的将对象成员的值赋值给另一个对象成员,这里需要注意深浅拷贝的问题。