用于单个所有者和多个引用的智能指针
Smart pointer for single owner and multiple references
以前我使用原始指针实现了链表和树。当我尝试使用智能指针实现时,我遇到了以下问题,因为我不知道该为只有一个所有者但有0个或多个引用的指针使用什么:
举个例子,我们用一个二叉树:
对于初学者来说,节点应该是指针的唯一"所有者":节点与树一起生存和死亡,所以对我来说,让它们成为unique_ptr
而不是shared_ptr
:是有意义的
class Tree {
std::unique_ptr<Node> root_;
}
class Node {
std::unique_ptr<Node> left_child_, right_child_;
}
然后我不得不做一个这样的算法:
Node * node = root_.get(); // <-- what type should node be??
while(node) {
if (node->left_count < node->right_count) {
node = node->left_child_.get();
} else {
node = node->right_child.get();
}
}
// do something on node
但我不喜欢使用原始指针。那么node
应该是什么样的智能指针呢?这个想法是,它不应该拥有指针的所有权。我读到weak_ptr
——看起来像我想要的——只适用于shared_ptr
,但我再次认为这里不需要shared_ptr
的开销。在任何时候,都会有一个并且只有一个所有者。
沿着链接列表的相同行:
class LinkedList {
std::unique_ptr<Node> first_;
/** ?? type ?? **/ last_;
}
for (/*?? type ??*/ n = first_; n != last_; n = n->next) {
}
编辑
我不喜欢使用原始指针(除了在C++中不再使用它们之外)的原因是,我想(通过接口)将它们暴露在外部:应该很清楚,它们不应该被释放。smart pointer
应该是明智的选择。
也许你在这里过度工程化了。只要外部客户端尊重它们不参与对象生存期的事实,它们就可以使用原始指针。如果你真的想成为纯粹主义者,那么你需要使用shared_ptr并返回weak_ptr。请注意,您实际上可能需要这样做,因为为了构建或维护数据结构,内部指针可能需要临时共享。
另一种选择是在数据结构中使用unique_ptr,并创建自己的自定义智能指针,该指针使用unique_pr::get返回的原始指针。我认为一个好名字应该是proxy_ptr,甚至可以有这样的东西:proxy_ptr p=make_proxy(yourUniquePtr.get());
相关文章:
- 智能指针作为无序映射键,并通过引用进行比较
- 智能指针(唯一指针)和引用
- 从引用创建指向基类的智能指针
- 智能指针的 std::swap 是否保证引用保持不变?
- 引用计数智能指针的正确实现
- 引用计数智能指针如何避免或处理引用计数器溢出?
- 在智能指针的反引用值上调用 std::move()
- 将常量引用转换为智能指针而不复制
- 有共享引用计数智能指针这样的东西吗
- 使用智能指针将右值引用绑定到抽象类的替代方法
- 为引用计数的智能指针检测内存泄漏的设计模式
- 用C++智能指针构造多对多/双向引用
- 关于智能指针中取消引用和成员选择运算符的定义
- 跨越dll边界的C++智能引用
- C++:为智能指针的字段隐式保留右值引用
- 从原始指针/引用创建智能指针
- 侵入式智能指针的引用计数器
- 为什么在删除原子引用计数智能指针中的数据之前需要获取屏障
- 不同的智能指针可以引用同一个对象吗?
- 如何按引用或值返回智能指针 (shared_ptr)