为什么 List 类必须包含 Node 结构作为私有成员C++
Why List class has to contain a Node struct as a private member C++
Mark Weiss的数据结构书中链表的实现让我有点困惑。
List 类包含内部的节点结构,如下所示。
...
class List {
private:
struct Node {
...
};
...
public:
...
private:
int theSize;
Node *head;
Node *tail;
};
我的问题是,在 List 类中拥有一个 Node 结构真的有必要吗?我认为只要 List 类包含指向标题和尾节点的指针就足够了。将 Node 结构作为私有成员有什么优势?
谢谢!
将 Node 结构声明为 List 类中的私有声明的原因是将其保留为实现的私有声明。这将确保实现的特定细节不会泄漏到公共接口中。这是从内部实现详细信息中抽象接口的有效方法,使这些详细信息可以自由更改,而不会影响 List 类公共接口的用户。
我的问题是,在 List 类中拥有一个 Node 结构真的有必要吗?
这不是必需的,但更好。
-
List::Node
可以不同于Set::Node
,可以不同于DList::Node
,可以不同于Map::Node
。在List
之外有一个仅用于实现List
的Node
类是没有意义的。你必须创建ListNode
、SetNode
等,使它们成为不同的类型。 -
将
Node
作为嵌套类可确保类的详细信息特定于List
。 -
它不会用类型名称污染全局命名空间,这些类型名称在
。List
的实现之外没有用 -
它允许
Node
private
List
。Node
的详细信息不会向List
的用户公开,除非List
的实现选择这样做。在大多数情况下,它不会暴露。
相关文章:
- 将成员变量添加到共享库中的类中,不会破坏二进制兼容性吗
- 对RValue对象调用的LValue ref限定成员函数
- 为什么使用 "this" 指针调用派生成员函数?
- 具有奇怪重复模板模式的派生类中的成员变量已损坏
- 助记符和指向成员语法的指针
- 用于访问容器<T>数据成员的正确 API
- 内置函数可查看CPP中的成员变量
- 是否可以初始化不可复制类型的成员变量(或基类)
- 如果C++类在类方法中具有动态分配,但没有构造函数/析构函数或任何非静态成员,那么它仍然是POD类型吗
- 找不到成员对象:没有名为get_event()的成员,也处理多态性和向量
- 嵌套在类中时无法设置成员数据
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 将函数类成员映射到类本身内部
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 将Ref对象作为类成员
- 将包含C样式数组的对象初始化为成员变量(C++)
- 静态数据成员的问题-修复链接错误会导致编译器错误
- 将公共但非静态的成员函数与ALGLIB集成
- 多成员Constexpr结构初始化
- 我们可以访问一个不存在的联盟的成员吗