C++序列式容器(STL序列式容器)是 C++ STL(标准模板库)中的容器类,用于存储有序的数据序列,其中每个元素都可以通过其在序列中的位置进行访问,同时支持随机访问、迭代器等一系列通用的操作。
在 C++ STL 中,序列式容器包括以下几种:
vector:Vector 是一个可变大小的序列,底层使用动态数组实现,支持高效的随机访问和在末尾插入、删除元素。在进行大量随机访问时表现良好,但在较多插入和删除操作时性能较差。
deque:Deque 是一个双向队列,底层使用连续的存储块(chunk)实现,支持在两端插入、删除元素,也可以进行随机访问。Deque 相比于 vector 具有更好的随机插入和删除性能,但在进行随机访问时性能略逊于 vector。
list:List 是一个链表,底层采用双向链表实现,支持高效的插入和删除操作,但不支持随机访问。插入和删除操作的效率比 vector 和 deque 高,但是迭代器性能较差。
forward_list:单向链表,与 list 的区别在于它是单向的。
array:Array 是一个固定大小的数组,与 vector 相似,但一旦创建大小就不能改变。数组是内存中分配空间最直接和最有效的方法,支持高效的随机访问。
这些序列式容器都是基于 STL 中的迭代器实现的,在使用时可以通过迭代器来访问容器中的元素,并支持对元素进行增、删、改、查等一系列操作,方便快捷地处理各种有序数据。