Object 创建另一个实例,而不是修改指向的实例

Object creates another instance instead of modifying the one that's pointed

本文关键字:实例 修改 创建 另一个 Object      更新时间:2023-10-16

在我的主要中,我有变量:

ProcessManager mng;
MemoryManager mem;
dysk disk;

我正在尝试使用这些指针(也是主要的)

std::shared_ptr<MemoryManager> wsk= std::make_shared<MemoryManager>(mem) ;
std::shared_ptr<dysk> wsk_d = std::make_shared<dysk>(disk);

将这些对象传递给我的 Antoher 对象的实例(通过构造函数:

Interpreter interpreter(wsk,wsk_d);

但看起来 Intepreter 创建了自己的磁盘实例,为什么?

class Interpreter
{
private:
    std::shared_ptr<PCB> pcb;
    std::shared_ptr<MemoryManager> mm;
    std::shared_ptr<dysk> disk;
}
这就是

std::make_shared的作用:使用传递的参数创建一个新对象以传递给合适的构造函数。在您的情况下是复制构造函数。

也就是说,声明

std::shared_ptr<MemoryManager> wsk= std::make_shared<MemoryManager>(mem);

相当于

std::shared_ptr<MemoryManager> wsk(new MemoryManager(mem));

如果你想让你的共享指针引用现有对象,那么你需要使用

例如
std::shared_ptr<MemoryManager> wsk(&mem);

但这会带来其他问题,因为当最后一个共享指针被破坏时,它将尝试释放内存,这对于不是由 new 创建的对象是不可能的。对此有两种解决方案:创建一个(或使用现有的)null删除器,它实际上不会delete任何东西;或者让共享指针处理对象的完整所有权(从创建到销毁)。

这就是你应该如何看待智能指针,而不是作为一种自删除指针,而是从资源所有权的角度来看。