您的位置:首页 > 编程语言 > C语言/C++

浅谈C++容器(六)

2009-08-10 18:15 309 查看
容器适配器



STL
中包含三种适配器:栈stack
、队列queue
和优先级priority_queue


适配器是容器的接口,它本身不能直接保存元素,它保存元素的机制是调用另一种顺序容器去实现,即可以把适配器看作“它保存一个容器,这个容器再保存所有元素”。

STL
中提供的三种适配器可以由某一种顺序容器去实现。默认下stack
和queue
基于deque
容器实现,priority_queue
则基于vector
容器实现。当然在创建一个适配器时也可以指定具体的实现容器,创建适配器时在第二个参数上指定具体的顺序容器可以覆盖适配器的默认实现。

由于适配器的特点,一个适配器不是可以由任一个顺序容器都可以实现的。

栈stack
的特点是后进先出,所以它关联的基本容器可以是任意一种顺序容器,因为这些容器类型结构都可以提供栈的操作有求,它们都提供了push_back
、pop_back
和back
操作;

队列queue
的特点是先进先出,适配器要求其关联的基础容器必须提供pop_front
操作,因此其不能建立在vector
容器上;

优先级队列priority_queue
适配器要求提供随机访问功能,因此不能建立在list
容器上。

来自:blog.csdn.net/acosoft
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: