找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1823|回復: 0
打印 上一主題 下一主題
收起左側

疑神疑鬼找bug

[復制鏈接]
跳轉到指定樓層
樓主
ID:127229 發(fā)表于 2016-6-19 02:12 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
昨晚遇到神奇問題,網關做壓力測試,在CPU很高的時候會崩潰,看堆棧,都是崩潰在_heap_alloc這個函數里面,百思不得其解,以為是內存碎片導致的,寫了一段檢測代碼,可的捕獲到內存碎片嚴重,new 幾個字節(jié)都會失敗,特別是在cpu高的時候,以為是我大量使用std::string 和map之類容器問題,以為找到了原因,然后就是各種折騰,折騰了一晚上沒解決。今天早上睡了個飽覺,過來再想出了一下,感覺不應該是內存碎片的問題。如果是內存碎片,不應該在堆分配時拋訪問越界異常,然后使用分解方法,把一個個模塊拆下來單獨測,搞了一上午,終于找到原因了,原來在寫日志模塊里面,有一個多線程寫環(huán)型隊列加鎖有問題,沒鎖成。就這樣導致了多線程同時操作queue,導致堆被破壞,在_heap_alloc時,可有是內部進行了資源回收整理,然后就崩潰了。改了二行代碼,把bug修復了,中午吃飯時就讓壓力在跑,跑了幾百萬,啥事都沒了。

后來總結了一下,這種神奇問題基本都是自已的事情,想在操作系統(tǒng)上找理由是不行的。



分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表