网站首页 > 技术文章 正文
#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
using namespace std;
#include<string>
/*
void test()
{
Person p1("张三", 18);
Person p2("李四", 20);
p1 = p2; // 预期把 p1 改为 李四 20,但是运行报错 (报错原因见下面特别说明)
}
解决:赋值运算符重载
*/
class Person
{
public:
Person() {}
Person(char* name, int age) // 有参构造函数 初始化对象
{
this->m_Name = new char[strlen(name) + 1];
strcpy(this->m_Name, name);
this->m_Age = age;
}
~Person() // 析构函数,释放堆区空间
{
if (this->m_Name != NULL)
{
delete[] this->m_Name;
this->m_Name = NULL;
}
}
----------------------------------------------------------------------------------------------
//赋值运算符重载
Person& operator=(Person & p1) // p2 = p1 赋值运算符为双目运算符,有两个参数
{
// 释放自己(p2)堆区的数据
if (this->m_Name != NULL)
{
delete[] this->m_Name;
this->m_Name = NULL;
}
// 给自己(p2)开辟新空间,将传入的p1赋进去 // 开辟了新空间,就不会出现浅拷贝重复释放的问题了
this->m_Name = new char[strlen(p1.m_Name) + 1];
strcpy(this->m_Name, p1.m_Name);
this->m_Age = p1.m_Age;
return *this;
}
----------------------------------------------------------------------------------------------
public:
char* m_Name;
int m_Age;
};
int main()
{
Person p1("张三", 18);
Person p2("李四", 20);
p2 = p1;
// 预期把 p2 改为 张三 18,但是运行报错( 语法没有错误,其实报错的原因出现在析构函数调用delete上)
/*
特别说明:运行报错的原因
在经行对象实例化过程中,会调用4个函数:默认构造、拷贝构造、析构、 operator=
但是 operator= 只是简单的值拷贝,即 浅拷贝
当对象 p1 中有堆上属性时候, p2 = p1,就使得2个指针指向了同一块内存
当析构释放内存 p1 和 p2 时,会使同一内存会被释放2次,因此报错
赋值运算符重载的意义:将浅拷贝转变为深拷贝 (原赋值运算符是浅拷贝)
*/
cout << "p1的姓名 : " << p1.m_Name << " 年龄: " << p1.m_Age << endl;
cout << "p2的姓名 : " << p2.m_Name << " 年龄: " << p2.m_Age << endl;
return EXIT_SUCCESS;
}
说明:赋值运算符重载函数的返回值类型
1、 void 也可以,但有缺陷,如果p3 = p2 = p1, 第一次运算后会出现情况: p3 = void, 显然不符合传参类型
2、因此传回本体, Person&
再说明:比如 << = 前置++ 这一类需要实现链式编程的符号重载,返回值一般都是返回引用本体!
- 上一篇: 在C++中,如何避免出现Bug?
- 下一篇: 实例讲解C语言函数指针定义及回调函数应用
猜你喜欢
- 2025-08-02 C|在一个结构体嵌套一个共用体实现一体多用
- 2025-08-02 C++中,常用的强制类型转换函数
- 2025-08-02 如何使用C语言编程实现一个推箱子游戏?技术核心和算法实现
- 2025-08-02 C++20 新特性(24):模板访问权限和typename的放宽
- 2025-08-02 C++零基础到工程实践
- 2025-05-14 “Rust真能防住C代码里的那些老问题吗?我们做了个实验验证”
- 2025-05-14 C语言连续生成不同的随机数方法实例加程序
- 2025-05-14 C++20尝鲜:新增语法糖
- 2025-05-14 C 语言的整数提升
- 2025-05-14 C语言之位运算符
- 10-02基于深度学习的铸件缺陷检测_如何控制和检测铸件缺陷?有缺陷铸件如何处置?
- 10-02Linux Mint 22.1 Cinnamon Edition 搭建深度学习环境
- 10-02AWD-LSTM语言模型是如何实现的_lstm语言模型
- 10-02NVIDIA Jetson Nano 2GB 系列文章(53):TAO模型训练工具简介
- 10-02使用ONNX和Torchscript加快推理速度的测试
- 10-02tensorflow GPU环境安装踩坑日记_tensorflow配置gpu环境
- 10-02Keye-VL-1.5-8B 快手 Keye-VL— 腾讯云两卡 32GB GPU保姆级部署指南
- 10-02Gateway_gateways
- 最近发表
-
- 基于深度学习的铸件缺陷检测_如何控制和检测铸件缺陷?有缺陷铸件如何处置?
- Linux Mint 22.1 Cinnamon Edition 搭建深度学习环境
- AWD-LSTM语言模型是如何实现的_lstm语言模型
- NVIDIA Jetson Nano 2GB 系列文章(53):TAO模型训练工具简介
- 使用ONNX和Torchscript加快推理速度的测试
- tensorflow GPU环境安装踩坑日记_tensorflow配置gpu环境
- Keye-VL-1.5-8B 快手 Keye-VL— 腾讯云两卡 32GB GPU保姆级部署指南
- Gateway_gateways
- Coze开源本地部署教程_开源canopen
- 扣子开源本地部署教程 丨Coze智能体小白喂饭级指南
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (76)
- js判断是否是json字符串 (75)
- c语言min函数头文件 (77)
- asynccallback (87)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 无效的列索引 (74)