复制和修改shared_ptr

Copy and modify a shared_ptr

本文关键字:ptr shared 修改 复制      更新时间:2023-10-16

我想知道如何"复制"shared_ptr并修改内容。

在下面的示例中,创建了一个"模板人",我想将其用作每个机构都会从中复制的"人"。但是,当 std::shared_ptr p2 被分配template_person p2 中的每个修改也会影响template_person。有没有办法避免这种情况,或者我应该使用普通指针?

这是我的第一个方法。我想这样做以消耗更少的内存。

#include <iostream>
#include <memory>
#include <string>
class Person{
public:
~Person() {}
Person(int a, std::string b) : age_(a), name_(b) {}
void set_age(int x) { age_ = x; }
int age() { return age_; }
private:
int age_;
std::string name_;
};
int main () {
std::shared_ptr<Person> template_person = std::make_shared<Person>(10, "test");
std::shared_ptr<Person> p2 = template_person;
p2->set_age(20);
std::cout << p2->age() << " " << template_person->age() << std::endl;
//prints 20 20
return 0;
}

使用复制构造函数:

auto p2 = std::make_shared<Person>(*template_person);

我认为您缺少共享指针的重点。通过具有指向Person实例的共享指针,您可以说Person是共享资源,也就是说,无论您使用哪个shared_ptr实例来访问该资源,您都将始终更改相同的资源。

您要实现的只是复制Person对象。假设你有一个合格的复制构造函数(这在你的例子中是微不足道的(,只需摆脱共享指针和复制构造p2

int main () {
Person template_person {10, "test"};
Person p2 = template_person;
p2.set_age(20);
std::cout << p2.age() << " " << template_person.age() << std::endl;
}

似乎你想要的是"深拷贝"而不是"共享"对象.
智能指针的作用类似于原始指针,因此如果通过指向共享资源的指针之一进行任何更改,共享资源将发生变化.
所以请使用复制构造函数而不是std::shared_ptr

const Person template_person{ 10, "test" };
Person p2 = template_person;
p2.set_age(20);