
赋值运算符重载用于解决赋值操作的浅拷贝问题;

#include<iostream>
#include<string>
using namespace std;
class Person
{
public:
int *m_age;
//构建函数
Person(int age)
{
//将年龄数据开辟到堆区;
m_age = new int(age);
}
//重载赋值运算符
Person& operator=(Person& p)
{
if (m_age)
{
delete m_age;
m_age = NULL;
}
//编译器提供的拷贝;浅拷贝
//m_age=p.m_age;
//深拷贝;
m_age = new int(*p.m_age);
//返回自身,实现链式编程;
return *this;
}
//析构函数
~Person()
{
if (m_age)
{
delete m_age;
m_age = NULL;
}
}
};
int main()
{
Person p1(18);
Person p2(20);
Person p3(30);
//赋值
p1 = p2=p3;
cout << *p1.m_age << endl;
cout << *p2.m_age << endl;
cout << *p3.m_age << endl;
system("pause");
return 0;
}
本文探讨了C++中赋值运算符重载的重要性,主要针对浅拷贝引发的问题进行了解释。通过示例代码展示了如何在Person类中实现深拷贝,以确保对象的独立性和内存管理的正确性。通过重载赋值运算符,避免了成员指针在赋值操作后的错误共享,确保每个对象拥有自己独立的内存空间。
2838

被折叠的 条评论
为什么被折叠?



