《STL源码剖析常见面试问题》
生活随笔
收集整理的這篇文章主要介紹了
《STL源码剖析常见面试问题》
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1.? 當vector的內存用完了,它是如何動態擴展內存的?它是怎么釋放內存的?用clear可以釋放掉內存嗎?是不是線程安全的?
(1). vector內存用完了,會以當前size大小重新申請2*size的內存,然后把原來的元素復制過去,把新元素插上,然后釋放原來的內存。
(2). 一般我們釋放vector里的元素使用clear,其實它不能釋放內存,要想釋放內存要使用swap,這樣:
| 1 2 3 4 5 6 | vector<type>?v; // .... 這里添加許多元素給v // .... 這里刪除v中的許多元素 vector<type>(v).swap(v); // 此時v的容量已經盡可能的符合其當前包含的元素數量 // 對于string則可能像下面這樣 |
(3). 引用《effective stl》的第十二條:當涉及 STL容器和線程安全性時,你可以指望一個 STL庫允許多個線程同時讀一個容器,以及多個線程對不同的容器做寫入操作。你不能指望 STL庫會把你從手工同步控制中解脫出來,而且你不能依賴于任何線程支持。必須自己去寫多線程安全措施。
總結
以上是生活随笔為你收集整理的《STL源码剖析常见面试问题》的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: volatile、const的用法
- 下一篇: 成都欢乐谷让带吃的吗