一、构造函数
(1)构造函数作用:是为了初始化类对象。如果定义一个类之后,没有定义构造函数的话,编译器会自动生成一个构造函数。
(2)构造函数的类型:构造函数、拷贝构造函数、赋值构造函数。
(3)什么时候使用拷贝构造函数和赋值构造函数?
在设计类的时候,一般来说可以分为两种情况,一种是类成员变量中带有指针,另一种是类成员中不带有指针。
- 不带有指针:如果类成员变量中不带有指针的话,那么默认的拷贝构造函数、赋值构造函数就够用,采用的浅拷贝方式。
- 带有指针:如果类成员变量中带有指针的话,那么需要实现对应的 拷贝构造函数、赋值构造函数以及析构函数。采用的是深拷贝的方式。
二、浅拷贝
如果说类成员变量中不带有指针,编译器在编译的时候,采用默认的拷贝构造函数、赋值构造函数的时候,默认的是一个一个的复制过去。
不带有指针的情况,使用默认的拷贝构造函数、赋值构造函数比如:
三、深拷贝
3.1 为什么要使用深拷贝
如果类成员函数中带有指针,那么使用的默认的拷贝构造函数、赋值构造函数的时候,无法达到预期效果。
如果带有指针,采用默认的拷贝构造 or 拷贝复制:
会导致以下问题:
(1)如果test a的指针指向的值改变,那么test b中的值也会改变
(2)没有实现真正意义上的拷贝:test a的指针和test b的指针指向同一个位置,没有实现真正意义上的拷贝。应该为test b中指针指向一个新的地址address1,address1里面存放的值是和test a中指针指向地址中存放的值。
因此,需要采用深拷贝。
3.2 深拷贝
如图所示,深拷贝与浅拷贝不同,深拷贝是重新分配一块内存,并让类中指针指向该内存地址,并且该内存存放的值与test a中指针指向的值一样。
对于类成员
4、拷贝构造函数
4.1 拷贝构造函数
如果一个构造函数的第一个参数是自身类类型的引用,且任何额外的参数都是默认值,则此构造函数为拷贝构造函数
4.2 实现
test(const test &test_a) : number(test_a.number),numberPointer(test_a.numberPointer){
cout << "拷贝构造函数" << endl;
}
拷贝构造函数的入参一定是类对象的引用
4.3 拷贝构造函数的调用时机
1、当函数参数为类对象的时候
#include <iostream>
#include <vector>
using namespace std;
class test{
public:
test(){
}; //默认构造函数
test(const test &test_A){
cout<<"拷贝构造函数"<<endl;
}; //拷贝构造函数的参数值不变,为什么不能加上const呢?构造函数应该不应加上cost吧
test operator = (const test& a){
//赋值构造函数
cout