c++中vector使用的小问题
接手項目原有代碼,在昨天接到bug提示,一條數據處理時程序崩潰,于是有了這個查找問題的小總結。
gdb調試時問題定位到:malloc(): smallbin double linked list corrupted,然后看了那塊兒的代碼,并沒有發現有問題,于是進入c++冥想時刻:c++是一個神奇的語言,很多崩潰問題出現的地方并不是真實的,就好比一個人后背總疼,貼了膏藥拍了片子都沒發現問題,后來醫生會診,內科說這是心梗的前兆,問題在于血管堵塞,于是病好了,背不疼了。于是結束冥想,一路向前查找代碼,發現很早的一個數據處理的地方有多次的vector擴容,當然這個本身沒有問題,這個是vector的一個機制,當空間不夠用時,它會進行以下操作:
1、尋找更大空間
2、將原數據復制過去
3、釋放原空間
那么,就需要提前reserve,預留空間,提高效率,在這個代碼里,原作者同樣做了reserve,但是由于數據不規整,就是與原作者的理想狀態有點差異,導致了reserve的空間依然不足,就多次進行了另外的擴容,多次的申請空間,釋放空間,會產生內存碎片,于是乎,在后面代碼中同樣進行多次申請與釋放的時候,就出現申請的內存不夠,失敗的問題。
關于vector擴容,使用了一個測試代碼:
主要就測試擴容規則,在vs和linux中是不太一樣的,vs中是1.5倍,Linux下是2倍。
以上,有問題請指正,謝謝!
總結
以上是生活随笔為你收集整理的c++中vector使用的小问题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python 获取 字典中的指定键_py
- 下一篇: C/C++预处理指令