当前位置: 首页 > news >正文

深拷贝、浅拷贝、移动语义

C++ 中的拷贝方式

1. 深拷贝(Deep Copy)

定义

深拷贝会复制对象的全部内容,包括对象中动态分配的资源。新对象与原对象完全独立,任何对新对象的修改都不会影响原对象。

实现

通常通过显式的拷贝构造函数或拷贝赋值运算符,手动分配新内存并复制资源。

示例

#include <iostream>
#include <cstring>class MyClass {char* data;public:MyClass(const char* str) {data = new char[strlen(str) + 1];strcpy(data, str);}// 深拷贝构造函数MyClass(const MyClass& other) {data = new char[strlen(other.data) + 1];strcpy(data, other.data);}~MyClass() {delete[] data;}void print() const {std::cout << data << "\n";}
};int main() {MyClass obj1("Hello");MyClass obj2 = obj1;  // 调用深拷贝构造函数obj2.print();         // 输出: Helloreturn 0;
}

特点

1.深拷贝是安全的,原对象和新对象的资源完全独立。
2.对象中有动态资源时需要手动实现深拷贝。
3.较耗费性能(特别是资源较大时)。

2. 浅拷贝(Shallow Copy)

定义

浅拷贝只复制对象中的指针或引用,而不复制它们所指向的实际资源。新对象和原对象共享同一块资源。

问题

如果不小心释放了共享的资源,会导致其他对象指向无效的内存,产生 悬挂指针(Dangling Pointer)。

示例

#include <iostream>
#include <cstring>class MyClass {char* data;public:MyClass(const char* str) {data = new char[strlen(str) + 1];strcpy(data, str);}// 默认浅拷贝(未自定义拷贝构造函数时)MyClass(const MyClass& other) = default;~MyClass() {delete[] data;}void print() const {std::cout << data << "\n";}
};int main() {MyClass obj1("Hello");MyClass obj2 = obj1;  // 浅拷贝,指向同一资源obj1.print();         // 输出: Helloobj2.print();         // 输出: Helloreturn 0;
}

特点

1.浅拷贝速度快,因为它仅复制指针的地址。
2.容易产生悬挂指针或资源泄漏问题。

3. 移动语义(Move Semantics)

定义

移动语义会将资源从一个对象“转移”到另一个对象,而不会创建或复制新的资源。原对象的资源被“搬走”,进入“有效但未定义状态”。

实现

使用移动构造函数和移动赋值运算符。

示例

#include <iostream>
#include <utility> // for std::moveclass MyClass {char* data;public:MyClass(const char* str) {data = new char[strlen(str) + 1];strcpy(data, str);}// 移动构造函数MyClass(MyClass&& other) noexcept : data(other.data) {other.data = nullptr;  // 释放原对象的所有权}~MyClass() {delete[] data;}void print() const {std::cout << (data ? data : "Empty") << "\n";}
};int main() {MyClass obj1("Hello");MyClass obj2 = std::move(obj1);  // 调用移动构造函数obj2.print();                   // 输出: Helloobj1.print();                   // 输出: Emptyreturn 0;
}

特点

1.移动语义速度快,不需要深拷贝。
2.常用于临时对象或需要高效转移资源的场景。
3.需要实现移动构造函数和移动赋值运算符。

4. 对比总结

拷贝方式深拷贝浅拷贝移动语义
实现复杂度较高,需要手动复制资源简单,默认行为需要手动实现移动构造和赋值
效率慢,涉及内存分配和复制快,只复制指针非常快,只转移资源所有权
资源独立性独立的资源副本共享资源资源被转移,独占
适用场景资源独立且需频繁复制快速拷贝,无需独立资源资源需要转移时,高效操作

5.总结

  • 深拷贝:适用于需要独立资源的场景,比如资源管理类(文件、内存等)。
  • 浅拷贝:简单但容易导致问题,仅适用于无需独立资源的情况。
  • 移动语义:是现代 C++ 的高效资源管理方式,适合转移资源的场景。
http://www.lryc.cn/news/528225.html

相关文章:

  • 双向链表在系统调度、游戏、文本编辑及组态方面的应用
  • 实践网络安全:常见威胁与应对策略详解
  • 关于2024年
  • Hive:Hive Shell技巧
  • Markdown Viewer 浏览器, vscode
  • 快速分析LabVIEW主要特征进行判断
  • 【Super Tilemap Editor使用详解】(十五):从 TMX 文件导入地图(Importing from TMX files)
  • JavaScript系列(45)--响应式编程实现详解
  • Lustre Core 语法 - 布尔表达式
  • python学opencv|读取图像(四十六)使用cv2.bitwise_or()函数实现图像按位或运算
  • C# 添加、替换、提取、或删除Excel中的图片
  • 工作总结:压测篇
  • 11JavaWeb——SpringBootWeb案例02
  • vs2022+tesseract ocr识别中英文 编译好的库下载
  • 状态模式——C++实现
  • 3.观察者模式(Observer)
  • Kotlin判空辅助工具
  • Electron学习笔记,安装环境(1)
  • 将 OneLake 数据索引到 Elasticsearch - 第 1 部分
  • 【C++】STL介绍 + string类使用介绍 + 模拟实现string类
  • Hive:基本查询语法
  • 日志收集Day008
  • 【解决方案】VMware虚拟机adb连接宿主机夜神模拟器
  • 基于金融新闻的大型语言模型强化学习在投资组合管理中的应用
  • 脚本运行禁止:npm 无法加载文件,因为在此系统上禁止运行脚本
  • 借DeepSeek-R1东风,开启创业新机遇
  • C# lock使用详解
  • 简易CPU设计入门:控制总线的剩余信号(四)
  • 使用 lock4j-redis-template-spring-boot-starter 实现 Redis 分布式锁
  • 22_解析XML配置文件_List列表