深拷贝是指拷贝对象时为指针成员重新分配内存并复制数据,确保各对象拥有独立内存。当类含有动态分配的指针成员时,必须实现深拷贝构造函数、析构函数和赋值操作符(三法则),以避免浅拷贝导致的内存问题。例如MyString类中,通过new分配新内存并用strcpy复制内容,实现深拷贝;同时需在赋值操作符中检查自赋值并释放旧资源。现代C++推荐使用智能指针或标准库容器替代手动内存管理,减少错误风险。有指针成员就需考虑深拷贝,否则易引发内存泄漏或悬空指针。

在C++中,当类包含指针成员时,拷贝对象默认使用的是浅拷贝(shallow copy),即只复制指针的值(地址),而不复制指针指向的数据。这会导致多个对象共享同一块堆内存,容易引发重复释放、悬空指针等问题。为避免这些问题,必须手动实现深拷贝构造函数。
什么是深拷贝?
深拷贝是指在拷贝对象时,不仅复制对象本身,还为其指针成员重新分配内存,并将原对象所指向的数据内容复制到新内存中。这样两个对象各自拥有独立的数据,互不影响。
何时需要实现深拷贝构造函数?
当类中包含以下任一情况时,应考虑实现深拷贝:
- 有指针成员变量(如char*、int*等)
- 动态分配了堆内存(使用new或new[])
- 需要遵守“三法则”(析构函数、拷贝构造函数、赋值操作符应同时定义)
如何实现深拷贝构造函数?
下面以一个管理字符串的简单类为例,展示深拷贝构造函数的实现方法:
立即学习“C++免费学习笔记(深入)”;
class MyString {
private:
char* data;
int length;
public:
// 构造函数
MyString(const char* str = "") {
length = strlen(str);
data = new char[length + 1];
strcpy(data, str);
}
// 析构函数
~MyString() {
delete[] data;
}
// 深拷贝构造函数
MyString(const MyString& other) {
length = other.length;
data = new char[length + 1]; // 为新对象分配独立内存
strcpy(data, other.data); // 复制真实数据
}
// 赋值操作符(也需深拷贝)
MyString& operator=(const MyString& other) {
if (this == &other) return *this; // 自赋值检查
delete[] data; // 释放原有资源
length = other.length;
data = new char[length + 1];
strcpy(data, other.data);
return *this;
}
// 辅助函数:打印字符串
void print() const {
std::cout zuojiankuohaophpcnzuojiankuohaophpcn data zuojiankuohaophpcnzuojiankuohaophpcn std::endl;
}};
关键点说明:
- 拷贝构造函数参数为const T&,避免无限递归
- 使用new为data分配新的内存空间
- 用strcpy等函数复制原始数据内容
- 务必同时重载赋值操作符,防止赋值时出现浅拷贝问题
常见错误与注意事项
实现深拷贝时容易忽略的问题:
- 忘记释放原内存(赋值操作符中)导致内存泄漏
- 没有处理自赋值情况
- 拷贝构造函数传值导致无限递归
- 未遵循“三法则”,只写拷贝构造而忽略析构或赋值
现代C++建议优先使用智能指针(如std::unique_ptr、std::shared_ptr)或标准库容器(如std::string、std::vector),它们自带正确的拷贝行为,可避免手动管理内存带来的风险。
基本上就这些。只要记住:有指针,就要考虑深拷贝;要深拷贝,就得自己写构造、析构和赋值。不复杂但容易忽略。










