我正在尝试在 C++ 中设计一个树类,但在节点破坏方面遇到了一些麻烦。
如果我销毁一个节点,我不想销毁它的整个子树,因为可能有其他东西指向它。所以显而易见的解决方案是使用引用计数。我有一个指向父节点的弱指针,以及一个指向子节点的共享指针向量。这样,如果一个节点被销毁,它的子节点只有在没有指向它们的情况下才会被销毁。
但是我在这里遇到了另一个问题:向节点添加子节点。weak_ptr 仅在已经存在指向对象的 shared_ptr 时才有效。如果我将一个子节点添加到一个节点,我不知道在哪里可以找到指向它的 shared_ptr。那么我在这里做什么呢?