c++ - 如何在 C++ 中实现自定义标准集合?

标签 c++ collections interface stl iterator

我想实现一个标准风格的自定义集合数据结构。已经有一个similar question在这个网站上,但是这个人明确询问不使用任何给定的标准功能。

实现应该与标准库的其余部分兼容并提供相同的接口(interface),例如迭代器和类型特征。我应该继承哪个基类以及我的类必须实现什么?

为了提供有关实际数据结构的信息,它是一个 hash map which values are stored continuously在内存中。在内部,我将使用两个 std::vector 和一个 std::unordered_map

最佳答案

Which base class should I inherit from

没有。标准容器不是多态的;它们的接口(interface)要求是根据必须支持的表达式非正式指定的。 (将来,它们可能会被正式指定为“概念”;但这还不是语言的一部分。)

what does my class have to implement?

请参阅 C++ 标准的 [container.requirements] 部分(当前为 C++11 的第 23.2 部分);特别是指定各种容器类型必须支持的操作的表。作为 HashMap ,它应该支持“无序关联容器”的要求。

关于c++ - 如何在 C++ 中实现自定义标准集合?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22299338/

相关文章:

具有泛型的 Java 接口(interface)应接受子类作为类型参数

c++ - 堆栈链接错误问题

c++ - 如何使用模板声明成员函数? (不是模板类)

java - Struts2:单选按钮、迭代和列表问题

java - 要映射的计时器类

delphi - 通用接口(interface)如何引用指向其类型参数的指针?

c++ - 派生类中的复制构造函数

c++ - view_as 在 Boost Polygon 库中的使用

java - 为什么 Collections 类包含独立(静态)方法,而不是将它们添加到 List 接口(interface)中?

c# - 实现接口(interface)和访问方法