1.复制构造函数
要求构造函数的参数为自身类类型的引用
类名::类名(const 类名 & 引用名,。。。)
调用复制构造函数的时机
当说明语句建立对象时,可以调用复制构造函数进行数据初始化,另外,当函数
具有类类型传值参数或者返回类类型值时,都需要调用复制构造函数,完成局部
对象的初始化。
深复制和浅复制
当类的数据成员是简单数据类型时,在创建对象时,默认复制构造函数工作的很好。
但是,如果数据成员资源是由指针指示的堆,在创建对象时,调用系统预定义的默认
复制构造函数,就只作指针复制,而不会重新分配内存空间,这样当程序运行时,
会产生异常,另外,当对象作用域结束后,析构函数又错误地重复释放堆,在这种
需要使用用户定义的复制构造函数。
自定义复制构造函数避免了不同对象共享内存的错误。这种复制方式成为“深复制”
对应于默认复制函数的数据简单复制,成为“浅复制”
深复制,例如
CLASS OBJ1=OBJ2 调用复制构造函数,OBJ1重新分配数据空间,跟
OBJ2数据内存隔离开,把OBJ2里面的数据拷贝给OBJ1,
========================================
内存分配方式:
1.静态存储区域分配,这块内存在程序的整个运行期间都存在,例如,static
2.在栈上创建,函数结束就释放,效率高,分配内存容量有限
3.从堆中分配,即动态分配,malloc或者new,释放free或者delete,生存期由程序员掌握
========================================
2.虚函数
在某基类中声明为 virtual 并在一个或多个派生类中被重新定 义的成员函数,
用法格式为:virtual 函数返回类型 函数名(参数表) {函数体};实现多态性,
通过指向派生类的基类指针或引用,访问派生类中同名覆盖成员函数
3.友元
友元可以访问类的所有成员包括私有成员。
友元是非对称的,非传递的。
F是A的友元,但A不是F的友元,
B是A的友元,C是B的友元,但C不是A的友元
友元函数:关键字冠于函数原型之前,友元函数通过参数访问类的私有数据,友元函数
不是类的成员
友元类:若F类是A的友元类,则F类的所有成员函数都是A的友元函数
4.纯虚函数
纯虚函数定义::
virtual void function()=0;
含有纯虚函数的类为虚类
虚类不能定义对象,继承类中必须重写纯虚函数,才可定义对象
关于QT中undefined reference to `vtable for 重新qmake即可