青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Daly的游戲人生

替代系統(tǒng)malloc/new--選擇合適的內(nèi)存跟蹤方案

 
替代系統(tǒng)自帶的malloc/new原因無非兩個(gè): 
reason 1. 做內(nèi)存profile或查找問題   
reason 2. 自定義的分配方案提高性能

不過文章[1]中說明了,替代全局new不是一個(gè)好做法. 其實(shí)要達(dá)到以上兩點(diǎn)目的,筆者認(rèn)為用valgrind工具鏈就可以了。

解決方案:
1. 用valgrind和massif
     valgrind的memcheck做內(nèi)存泄露和bug的查找, 里面的massif工具包做內(nèi)存性能profile, 足矣。比自己山寨的一個(gè)profiler要好。
     注意:tcmalloc目前還不能很好支持valgrind,  實(shí)測(cè)中jemalloc可以

2.  linux下C的程序可以用wrap的方式(相當(dāng)于python的decorator)
     編譯加上選項(xiàng):gcc -Wl,-wrap,malloc
     可以做到對(duì)malloc這個(gè)函數(shù),linker會(huì)調(diào)用__wrap_malloc代替之, 若要調(diào)用原來的malloc函數(shù)__real_malloc
     缺點(diǎn):依賴于編譯器支持; 對(duì)c++的new不起作用 --> 不實(shí)用
     啟示:這個(gè)方法作為function裝飾器,對(duì)于調(diào)試別的問題倒有幫助。(例如不改變函數(shù)的情況下,wrap一層,輸出些調(diào)試信息)
3. 用__malloc_hook
    參考: http://linux.die.net/man/3/__malloc_hook
     #include <malloc.h>
     void *(*__malloc_hook)(size_t size, const void *caller);
     缺點(diǎn):依賴GNU編譯工具鏈;  容易死循環(huán)(想利用原有malloc,要參考例子中,把原__malloc_hook變量保存起來使用,并恢復(fù)現(xiàn)場(chǎng))

4. LD_PRELOAD注入.so ,替代原
     環(huán)境變量LD_PRELOAD指定程序運(yùn)行時(shí)優(yōu)先加載的動(dòng)態(tài)連接庫,這個(gè)動(dòng)態(tài)鏈接庫中的符號(hào)優(yōu)先級(jí)是最高的。標(biāo)準(zhǔn)C的各種函數(shù)都是存放在libc.so.6的文件中,在程序運(yùn)行時(shí)自動(dòng)鏈接。使用LD_PRELOAD后,自己編寫的malloc的加載順序高于glibc中的malloc,這樣就實(shí)現(xiàn)了替換。用法 LD_PRELOAD=" ./mymalloc.so"
      缺點(diǎn):在生產(chǎn)環(huán)境不現(xiàn)實(shí)。因?yàn)長D_PRELOAD相當(dāng)于庫注入,有安全性問題,是必須禁止的。(生產(chǎn)環(huán)境很多時(shí)候用-static連接)
5. 用宏或另外的函數(shù)替代new/malloc
   比如定義一個(gè)宏或者指定的函數(shù),規(guī)定所有的分配釋放都調(diào)用他。這樣相當(dāng)于給項(xiàng)目引入了額外的代碼規(guī)則(而且是一立項(xiàng)就要遵循這個(gè)規(guī)則,否則該方法無效),不能很自然的new/delete, 如果分配和釋放調(diào)用得不一致,會(huì)產(chǎn)生問題的。某產(chǎn)品組就是用宏,然后加上__FILE__, __LINE__之類的信息。

 有時(shí)候valgrind的效率是個(gè)問題(尤其生產(chǎn)環(huán)境),這種方案有其價(jià)值所在, 就是代碼看上去比較ugly罷了

   用宏的例子:
   #define _New(Type, Catergory)                    (Type*)MyMemController::New((new Type), #Type, 1, sizeof(Type),   Catergory, __FILE__, __LINE__, false)
   #define _NewArray(Type, N, Catergory)          (Type*)MyMemController::New((new Type[N]), #Type, N, sizeof(Type)*(N), Catergory, __FILE__, __LINE__, true)

   
MALLOC的替代品:
     自己寫一個(gè)malloc其實(shí)很復(fù)雜,要考慮線程安全等各種問題,性能到頭來可能更差。google 的tcmalloc,  facebook使用的jemalloc.   多線程下性能較好,可以考慮使用。
     缺點(diǎn):筆者嘗試過。tcmalloc不能正確用valgrind,只能用自帶gperftools(運(yùn)行中會(huì)core)
                 jemalloc可以使用valgrind,不過還沒完全驗(yàn)證是否都準(zhǔn)確。
tcmalloc相關(guān):
    在64位系統(tǒng)上要裝libunwind, 對(duì)x86-64架構(gòu)使用還有些問題

源碼包的INSTALL文檔里面也提到了這個(gè)問題。
 CAUTION: if you install libunwind from the url above, be aware that
   you may have trouble if you try to statically link your binary with
   perftools: that is, if you link with 'gcc -static -lgcc_eh ...'.
   This is because both libunwind and libgcc implement the same C++
   exception handling APIs, but they implement them differently on
   some platforms.  This is not likely to be a problem on ia64, but
   may be on x86-64.

主要是64位機(jī)frame-pointer的影響, 他的profile工具里的backtrace用libunwind這個(gè)庫,這個(gè)庫又有版本問題,各種囧啊....
筆者試過系統(tǒng)x86-64, freebsd,用靜態(tài)鏈接。實(shí)際用了一下,問題很多很折騰,等他fix了再說吧.

windows下可以參考:

jemalloc暫時(shí)未發(fā)現(xiàn)有什么兼容性問題,運(yùn)行得挺好的。
 
Reference
[1] <不要重載全局operator new>

[2] effective c++條款50:了解new和delete的合理替換時(shí)機(jī)

[3] 游戲引擎中的內(nèi)存分配策略
[4] 更好的內(nèi)存管理jemalloc
[5] tcmalloc官網(wǎng)(gperftools)

posted on 2012-07-02 13:01 Daly 閱讀(7525) 評(píng)論(0)  編輯 收藏 引用 所屬分類: C/C++

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久夜色精品一区| 亚洲一区视频在线| 亚洲在线第一页| 亚洲精选在线观看| 久久精品99无色码中文字幕| 国产精品99久久久久久久vr| 欧美成人免费va影院高清| 久久国产精品久久久久久久久久 | 亚洲综合国产| 亚洲视频专区在线| 欧美日韩国产综合网| 亚洲激情电影中文字幕| 在线看欧美视频| 久久久久在线| 另类成人小视频在线| 国产午夜精品在线观看| 亚洲欧美日韩精品综合在线观看 | 亚洲午夜电影在线观看| 欧美日韩国内自拍| 亚洲免费观看高清在线观看| 一级成人国产| 欧美日韩在线亚洲一区蜜芽| 91久久精品国产91久久| 日韩视频一区二区在线观看| 欧美国产成人精品| 亚洲人成网站在线观看播放| 亚洲靠逼com| 欧美电影电视剧在线观看| 最新国产拍偷乱拍精品| 夜夜嗨网站十八久久| 欧美日韩国产黄| 亚洲午夜成aⅴ人片| 欧美与黑人午夜性猛交久久久| 国产精品一区二区欧美| 欧美在线一区二区三区| 嫩模写真一区二区三区三州| 亚洲乱码国产乱码精品精| 欧美激情一区在线| 夜夜嗨av色综合久久久综合网| 亚洲一区二区三区777| 国产欧美一区二区三区视频| 欧美在线视频观看| 欧美成人精品激情在线观看| 亚洲最黄网站| 国产九九精品视频| 久久亚洲精品一区二区| 亚洲黄色性网站| 午夜久久资源| 在线观看欧美亚洲| 欧美精品一区二区三区一线天视频| 一区二区不卡在线视频 午夜欧美不卡在 | 久久九九国产精品| 亚洲二区在线观看| 欧美日韩日本视频| 久久激五月天综合精品| 亚洲激情国产精品| 欧美亚洲一级片| 亚洲人成人一区二区三区| 国产精品久久久久久久一区探花| 久久xxxx精品视频| 亚洲人成亚洲人成在线观看| 欧美亚洲视频一区二区| 亚洲国产成人精品女人久久久 | 亚洲一区亚洲二区| 国内一区二区在线视频观看 | 国产夜色精品一区二区av| 你懂的国产精品| 亚洲一区国产精品| 亚洲国产成人一区| 久久精品亚洲乱码伦伦中文| 99精品国产一区二区青青牛奶| 国产午夜精品美女毛片视频| 欧美精品在线一区二区| 欧美在线国产| 亚洲图片在线| 亚洲国产精品久久久久婷婷老年| 久久久91精品国产| 亚洲综合视频1区| 亚洲激情网站| 国产综合久久久久久鬼色| 欧美日韩国产一区二区三区地区 | 欧美资源在线| 亚洲网站在线| 亚洲三级观看| 欧美韩日高清| 另类av导航| 久久―日本道色综合久久| 亚洲一区二区欧美| 99www免费人成精品| 亚洲国产精品久久| 一区二区三区在线视频播放| 国产欧美一级| 国产精品尤物| 国产精品夜夜嗨| 欧美偷拍另类| 欧美日韩免费网站| 欧美日韩在线播放一区| 欧美日韩免费一区二区三区视频| 欧美劲爆第一页| 欧美黄色网络| 欧美精品在线网站| 欧美日韩精品一区二区| 欧美理论电影在线观看| 欧美激情精品久久久久久久变态| 欧美sm重口味系列视频在线观看| 久久久久久亚洲精品杨幂换脸| 久久福利毛片| 久久婷婷激情| 欧美黄色小视频| 欧美母乳在线| 国产精品萝li| 国内激情久久| 亚洲高清视频在线| 亚洲精选大片| 亚洲欧美日韩国产一区二区| 亚洲欧美日本国产有色| 久久不见久久见免费视频1| 欧美一区成人| 久久综合九色九九| 亚洲高清不卡av| 在线亚洲成人| 久久国内精品视频| 免费观看国产成人| 欧美另类一区| 国产精品久久综合| 韩国欧美一区| 亚洲美女福利视频网站| 亚洲在线成人| 麻豆av一区二区三区| 亚洲国内高清视频| 亚洲一区免费视频| 久久一区中文字幕| 欧美视频免费看| 韩国女主播一区| 一本久久a久久免费精品不卡| 亚洲欧美国产精品专区久久| 久久亚洲不卡| 99re视频这里只有精品| 欧美一区国产一区| 欧美精品一区三区在线观看| 国产精品爽黄69| 亚洲二区在线观看| 午夜视频一区二区| 欧美岛国激情| 亚洲综合色自拍一区| 蜜臀av一级做a爰片久久| 国产精品a久久久久久| 伊人成人在线| 亚久久调教视频| 亚洲国产精品久久久久婷婷884| 亚洲性图久久| 欧美成人免费大片| 国产亚洲精品一区二区| a4yy欧美一区二区三区| 久久婷婷丁香| 亚洲婷婷综合久久一本伊一区| 老司机精品视频网站| 国产日本欧美一区二区三区| 日韩一区二区高清| 久久五月激情| 亚洲免费在线观看| 欧美日韩www| 亚洲国产日韩在线一区模特| 欧美一区永久视频免费观看| 亚洲人人精品| 男人插女人欧美| 国产视频一区在线| 香蕉久久国产| 99视频一区| 欧美精品首页| 亚洲麻豆av| 亚洲高清不卡一区| 美女精品自拍一二三四| 激情久久久久久久| 久久av红桃一区二区小说| 在线亚洲观看| 国产精品sm| 亚洲视频高清| 亚洲精品美女免费| 欧美成人dvd在线视频| 在线成人欧美| 免费成人美女女| 久久在线精品| 亚洲电影在线观看| 欧美1区2区视频| 久久久天天操| 在线不卡中文字幕播放| 久久午夜视频| 久久在线免费观看视频| 亚洲国产精品热久久| 亚洲第一在线综合网站| 免费欧美电影| 亚洲精品综合精品自拍| 亚洲人成在线播放| 欧美区日韩区| 中文在线一区| 亚洲在线1234| 狠狠久久婷婷| 欧美福利专区| 欧美日韩亚洲另类|