找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1823|回復(fù): 0
打印 上一主題 下一主題
收起左側(cè)

疑神疑鬼找bug

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

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



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

使用道具 舉報

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

本版積分規(guī)則

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

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表