当存在至少一个shared_ptr
时,weak_ptr
的控制块保持活动。如果共享指针是用make_shared
创建的,这意味着对象的整个内存都保持分配状态。(对象本身被正确地析构,但由于对象的控制块和内存是在一个块中分配的,就像make_shared
一样,它们只能一起释放。)
我的理解正确吗?
例如,在著名的"cache example"中,这种行为似乎代表了一个问题。对象的内存将永远保持分配状态。
这在任何实际情况下都是一个问题吗?在这种情况下(大对象和要使用weak_ptr
的意图),是否应该使用构造函数创建shared_ptr
?
发布于 2015-08-20 17:38:55
我在VS2013中尝试过,你完全正确。析构函数在销毁最后一个shared_ptr时调用,因此任何其他对象或与该对象关联的内存都将被销毁,但如果shared_ptr是用make_shared创建的,则在销毁最后一个weak_ptr之前,内存永远不会销毁。
我认为如果weak_ptrs ()失败了,清理或重置锁总是很好的,因为即使没有make_shared,它仍然会占用一些内存。
https://stackoverflow.com/questions/32113594
复制相似问题