浅拷贝和深拷贝

35 篇文章 2 订阅
一、浅拷贝和深拷贝
  所谓浅拷贝,就是由默认的拷贝构造函数所实现的对数据成员逐一赋值。若类中含有指针类型的数据,这种方式只是简单的把指针的指向赋值给新成员,但并没有给新成员分配内存,因此这种方式必然会导致错误。为了解决浅拷贝出现的错误,必须显示的定义一个拷贝构造函数,使之不但复制数据成员,而且为对象分配各自的内存空间,这就是所谓的深拷贝。

二、浅拷贝
  浅拷贝就是由默认的拷贝构造函数所实现的数据成员逐一赋值。通常默认的拷贝构造函数能够胜任这个工作,但是若类中含有指针类型的数据,这种数据成员逐一赋值的方式将会产生错误。
例:
class Student
{
public:
                Student( char *name ,int age)         //构造函数
                {
                                _name = new char [10];           //分配内存
                                strcpy(_name, name);
                                _age = age;
                }
                ~Student()
                {
                                 delete[] _name;                 //释放动态内存
                }
                 void display()
                {
                                cout << _name << "--" << _age << endl;
                }
private:
                 char *_name;
                 int _age;
};

int main()
{
                 Student st1("lisi" , 20);
                 Student st2(st1);               //调用默认的拷贝构造函数创建一个新的对象
                system( "pause");
                 return 0;
}



  程序运行,创建st1时调用构造函数 ,用运算符new从堆上分配一块空间,并用_name指向这块内存空间。在执行st2语句时,因为没有定义拷贝构造函数,所以调用默认的拷贝构造函数:
                Student( Student & st )
                {
                                _name = st ._name;                  //并没有为对象st2的数据成员_name分配新的内存空间
                                _age = st ._age;
                }

  主程序结束时,对象被逐个撤销,先撤销对象st2(因为st2后创建),撤销前先调用析构函数,用delete运算符释放所分配的内存空间;撤销对象st1时,第二次调用析构函数,因为这时_name所指向的内存空间已经被释放,企图对同一块内存空间释放两此,所以这时候程序出错。
执行过程如图:



三、深拷贝
 为了解决浅拷贝出现的错误,必须显示的定义一个拷贝构造函数,使之不但能复制数据成员,而且为指针分配各自的动态内存。
class Student
{
public:
                Student( char *name ,int age)         //构造函数
                {
                                _name = new char [10];           //分配内存
                                strcpy(_name, name);
                                _age = age;
                }
                Student( Student& st )                 //自定义的拷贝构造函数
                {
                                _name = new char [10];
                                 if (_name != NULL )
                                {
                                                strcpy(_name, st._name);
                                                _age = st._age;
                                }
                }
                ~Student()
                {
                                 delete[] _name;                 //释放动态内存
                }
                 void display()
                {
                                cout << _name << "--" << _age << endl;
                }
private:
                 char *_name;
                 int _age;
};

int main()
{
                 Student st1("lisi" , 20);
                 Student st2(st1);               //调用默认的拷贝构造函数创建一个新的对象
                system( "pause");
                 return 0;
}



在执行Student st2(st1)时调用自定义的拷贝构造函数,为st2._name分配自己的动态内存。程序的执行过程如图:

  • 5
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值