容器 (数据类型)
外观
在计算机科学中,容器是指一种类、数据结构、[1][2]或者抽象数据类型,其实例为其他类的对象。换言之,它们以一种遵循特定访问规则的方法来存储对象。容器的大小取决于其包含的对象(或元素)的数目。潜在的不同容器类型的实现可能在空间和时间复杂度上有所差别,这使得在给定应用场景中选择合适的某种实现具有灵活性。
概览
[编辑]容器可以三种方式看待:
- 访问:即访问容器中对象的方式。
- 存储:即存储容器中对象的方式。
- 遍历:即遍历容器中对象的方式。
典型的容器实现如下的方法:
- 创建一个新的空容器(即构造函数)。
- 向容器中插入对象。
- 从容器中删除对象。
- 删除容器中的所有对象(即清空)。
- 访问容器中的对象。
- 获取容器中对象的数目(即尺寸)。
并非所有设计遵循以上要求,例如C++标准库的std::array
不提供清空,而std::forward_list
不提供对象计数。
容器有时结合迭代器实现。
分类
[编辑]按存储类型
[编辑]单值或关联容器
[编辑]- 单值容器:每个对象在容器中被独立存储,并且其被直接或凭借迭代器访问。
- 关联容器:关联数组、映射或者字典是由键值对组成的容器,因此每一个键在给定容器中最多出现一次。如果一个值(对象)被存储在给定容器中,那么键可以用于寻找它。
图形容器
[编辑]部件工具箱使用特殊控件(也称作容器)去将其他控件分组(窗口、面板等)。除它们的图形特性之外,它们有和容器类一致的表现:它们存有它们子控件的列表,并且允许对子控件进行增加、删除或获取等操作。
不同实现
[编辑]- .NET: System.Collections (MSDN)(页面存档备份,存于互联网档案馆)
- ActionScript3: AS3Commons Collections Framework
- C++: C++标准库 (SC++L) or the obsolete 标准模板库 (STL)
- Java: Java集合框架(JCF)
- Objective-C: Foundation Kit的部分。
- PL/SQL: 集合[6]
- Python: 内置容器 list、dict、tuple和set,可使用collections(页面存档备份,存于互联网档案馆)模块进一步拓展。
- Scala: 在
scala.collection.mutable
andscala.collection.immutable
包中的可变及不可变容器。
参见
[编辑]参考资料
[编辑]- ^ Paul E. Black (ed.), entry for data structure in Dictionary of Algorithms and Data Structures. US National Institute of Standards and Technology.15 December 2004. Accessed on Oct 04, 2011.
- ^ Entry data structure in the Encyclopædia Britannica (2009) Online entry (页面存档备份,存于互联网档案馆) Accessed on Oct 04, 2011.
- ^ LIFO(investopedia.com). [2016-08-19]. (原始内容存档于2016-08-24).
- ^ FIFO(investopedia.com). [2016-08-19]. (原始内容存档于2016-08-09).
- ^ FIFO(businessdictionary.com). [2016-08-19]. (原始内容存档于2016-08-27).
- ^ PL/SQL Collections and Records. [2013-04-20]. (原始内容存档于2013-05-09).
外部链接
[编辑]- Container Data Structure Declaration and Initialization(页面存档备份,存于互联网档案馆)
- Container data structures(页面存档备份,存于互联网档案馆)
- Python SortedContainers module(页面存档备份,存于互联网档案馆) A fast implementation of sorted list, sorted dict, and sorted set data types in Python.