拷贝构造函数,常被称为X(X&)。
拷贝构造函数的作用:1.传值;2.传返回值; 3.对象初始化赋值。
当从一个“老对象”复制出一个“新对象”时,新对象将产生自己的内存空间,并且新对象具有和老对象一样的内存空间结构;老对象的变量(指针、数字、字符、字符串等定长类型)值都会被拷贝入新对象中。
但是,如果老对象中有堆内存,在新对象中并不会复制堆内存,而是指向老对象的堆内存。这就是浅拷贝,C++类会默认生成浅拷贝。
浅拷贝的局限性是:新老对象指向相同的堆内存空间,一个对象的堆内存发生改变,另外一个也随之改变。当对象析构时,这块堆内存将释放两次。
如果我们想将老对象的堆内存也拷贝到新对象,就必须构建自己的拷贝构造函数,在拷贝构造函数中为新对象开辟堆内存、赋值,这就是深拷贝。
下面的例子用最“热门”的String为例:
浅拷贝的实现很简单:
m_data=another.m_data; //直接赋值,指针指向相同的堆内存
深拷贝:
m_data = new char[strlen(another.m_data) + 1]; //先开辟空间
拷贝构造函数的作用:1.传值;2.传返回值; 3.对象初始化赋值。
当从一个“老对象”复制出一个“新对象”时,新对象将产生自己的内存空间,并且新对象具有和老对象一样的内存空间结构;老对象的变量(指针、数字、字符、字符串等定长类型)值都会被拷贝入新对象中。
但是,如果老对象中有堆内存,在新对象中并不会复制堆内存,而是指向老对象的堆内存。这就是浅拷贝,C++类会默认生成浅拷贝。
浅拷贝的局限性是:新老对象指向相同的堆内存空间,一个对象的堆内存发生改变,另外一个也随之改变。当对象析构时,这块堆内存将释放两次。
如果我们想将老对象的堆内存也拷贝到新对象,就必须构建自己的拷贝构造函数,在拷贝构造函数中为新对象开辟堆内存、赋值,这就是深拷贝。
下面的例子用最“热门”的String为例:
浅拷贝的实现很简单:
m_data=another.m_data; //直接赋值,指针指向相同的堆内存
深拷贝:
m_data = new char[strlen(another.m_data) + 1]; //先开辟空间
strcpy(m_data,another.m_data); //再赋值
#include <iostream.h>
class String
{
public:
String(const char