STL vector list deque区别与实现
1 vector
??? 向量 相當于一個數組
??? 在內存中分配一塊連續的內存空間進行存儲。支持不指定vector大小的存儲。STL內部實現時,首先分配一個非常大的內存空間預備進行存儲,即capacituy()函數返回的大小,當超過此分配的空間時再整體重新放分配一塊內存存儲,這給人以vector可以不指定vector即一個連續內存的大小的感覺。通常此默認的內存分配能完成大部分情況下的存儲。
?? 優點:(1) 不指定一塊內存大小的數組的連續存儲,即可以像數組一樣操作,但可以對此數組
????????????????? 進行動態操作。通常體現在push_back() pop_back()
????????????(2) 隨機訪問方便,即支持[ ]操作符和vector.at()
????????????(3) 節省空間。
?? 缺點:(1) 在內部進行插入刪除操作效率低。
????????????(2) 只能在vector的最后進行push和pop,不能在vector的頭進行push和pop。
????????????(3) 當動態添加的數據超過vector默認分配的大小時要進行整體的重新分配、拷貝與釋放
2 list
??? 雙向鏈表
??? 每一個結點都包括一個信息快Info、一個前驅指針Pre、一個后驅指針Post。可以不分配必須的內存大小方便的進行添加和刪除操作。使用的是非連續的內存空間進行存儲。
?? 優點:(1) 不使用連續內存完成動態操作。
????????????(2) 在內部方便的進行插入和刪除操作
????????????(3) 可在兩端進行push、pop
?? 缺點:(1) 不能進行內部的隨機訪問,即不支持[ ]操作符和vector.at()
????????????(2) 相對于verctor占用內存多
3 deque
?? 雙端隊列 double-end queue
?? deque是在功能上合并了vector和list。
?? 優點:(1) 隨機訪問方便,即支持[ ]操作符和vector.at()
????????????(2) 在內部方便的進行插入和刪除操作
????????????(3) 可在兩端進行push、pop
?? 缺點:(1) 占用內存多
?
使用區別:
???? 1 如果你需要高效的隨即存取,而不在乎插入和刪除的效率,使用vector
???? 2 如果你需要大量的插入和刪除,而不關心隨即存取,則應使用list
???? 3 如果你需要隨即存取,而且關心兩端數據的插入和刪除,則應使用deque
======================================================================
拓展參考:
?
Cplusplus - List
?
Cplusplus - Deque
?
Cplusplus - Vector
?
STL提供了三個最基本的容器:vector,list,deque
?
?
轉載于:https://www.cnblogs.com/mixer/archive/2011/01/07/2448103.html
總結
以上是生活随笔為你收集整理的STL vector list deque区别与实现的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: CSS截取字符串,兼容浏览器
- 下一篇: 啼开头的成语有哪些啊?