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

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í)測中jemalloc可以

2.  linux下C的程序可以用wrap的方式(相當(dāng)于python的decorator)
     編譯加上選項(xiàng):gcc -Wl,-wrap,malloc
     可以做到對malloc這個(gè)函數(shù),linker會調(diào)用__wrap_malloc代替之, 若要調(diào)用原來的malloc函數(shù)__real_malloc
     缺點(diǎn):依賴于編譯器支持; 對c++的new不起作用 --> 不實(shí)用
     啟示:這個(gè)方法作為function裝飾器,對于調(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)場)

4. LD_PRELOAD注入.so ,替代原
     環(huán)境變量LD_PRELOAD指定程序運(yùn)行時(shí)優(yōu)先加載的動態(tài)連接庫,這個(gè)動態(tài)鏈接庫中的符號優(yōu)先級是最高的。標(biāo)準(zhǔn)C的各種函數(shù)都是存放在libc.so.6的文件中,在程序運(yùn)行時(shí)自動鏈接。使用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)用得不一致,會產(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)行中會core)
                 jemalloc可以使用valgrind,不過還沒完全驗(yàn)證是否都準(zhǔn)確。
tcmalloc相關(guān):
    在64位系統(tǒng)上要裝libunwind, 對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 閱讀(7511) 評論(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>
            欧美一二区视频| 亚洲网站在线观看| 欧美成人69| 久久久久久黄| 久久夜色精品国产欧美乱| 欧美一进一出视频| 久久久久国产精品厨房| 欧美jizz19hd性欧美| 欧美激情四色 | 亚洲国产综合视频在线观看| 免费在线日韩av| 免费在线播放第一区高清av| 欧美电影免费| 一本色道久久综合亚洲精品小说 | 一本色道久久综合亚洲精品小说| 99精品视频免费观看| 亚洲在线视频免费观看| 国内精品久久久久久 | 欧美日韩一区二区三区| 国产精品久久久久久久久| 国产一区二区精品久久| 亚洲国产成人91精品| 亚洲午夜精品国产| 久久一本综合频道| 亚洲精品日产精品乱码不卡| 亚洲一区二区三区中文字幕| 久久久7777| 欧美午夜精品电影| 1204国产成人精品视频| 亚洲尤物视频网| 亚洲另类一区二区| 午夜精彩国产免费不卡不顿大片| 欧美伊人久久久久久久久影院| 久热综合在线亚洲精品| 日韩视频第一页| 久久久青草婷婷精品综合日韩| 欧美另类在线播放| 国产曰批免费观看久久久| 亚洲午夜电影在线观看| 欧美激情二区三区| 久久精品国产清高在天天线| 欧美视频在线不卡| 亚洲美女黄色| 欧美成人午夜视频| 欧美一区国产一区| 国产精品美女久久久浪潮软件| 最近中文字幕日韩精品| 久久免费视频在线观看| 亚洲香蕉伊综合在人在线视看| 欧美激情第4页| 136国产福利精品导航网址应用| 欧美一级大片在线观看| 在线中文字幕一区| 欧美日韩在线直播| 亚洲桃花岛网站| 91久久久在线| 久久久久9999亚洲精品| 国产一区视频观看| 久久久av毛片精品| 亚洲欧美日韩一区| 国产网站欧美日韩免费精品在线观看 | 亚洲第一在线| 久久久欧美精品| 在线看国产一区| 久久久综合视频| 久久精品中文字幕一区二区三区| 国产日韩欧美一区二区三区在线观看| 亚洲欧美日韩精品久久奇米色影视| 亚洲欧洲另类国产综合| 欧美激情第3页| 亚洲一区二区精品在线| 一区二区三区偷拍| 国产精品普通话对白| 欧美一区二区三区久久精品茉莉花 | 欧美午夜免费影院| 亚洲欧美另类中文字幕| 亚洲欧美在线播放| 黄色成人片子| 亚洲福利视频免费观看| 欧美激情精品久久久| 中文网丁香综合网| 午夜在线不卡| 亚洲精品久久久久久久久久久久久| 亚洲一二三四久久| 国产日韩视频| 蜜臀91精品一区二区三区| 久久天堂av综合合色| 亚洲巨乳在线| 亚洲女人天堂av| 亚洲国产91| 一区二区欧美日韩| 一区二区三区在线视频观看| 亚洲高清色综合| 国产精品萝li| 欧美搞黄网站| 国产精品亚洲综合色区韩国| 免费成人在线观看视频| 欧美日韩一区二区三区在线看 | 欧美日韩国产欧| 欧美在线免费一级片| 麻豆精品在线观看| 午夜精品一区二区三区四区| 久久久成人精品| 亚洲视频免费观看| 久久国产日韩| 亚洲免费影院| 欧美成人按摩| 久久精品国产69国产精品亚洲| 欧美gay视频| 久久免费偷拍视频| 国产精品视频免费观看www| 欧美电影免费网站| 国产日韩在线亚洲字幕中文| 亚洲精品国产无天堂网2021| 国产一区在线视频| 亚洲视频在线观看三级| 亚洲精品之草原avav久久| 亚洲一区二区三区四区五区黄| 亚洲激情成人在线| 久久精品一区二区三区不卡| 午夜精品福利视频| 欧美日韩在线精品| 亚洲韩国青草视频| 1024亚洲| 久久综合中文| 免费91麻豆精品国产自产在线观看| 欧美小视频在线| 亚洲精品一区在线观看| 亚洲欧洲在线免费| 免费观看一区| 欧美1区2区视频| 狠狠色综合播放一区二区| 午夜在线电影亚洲一区| 欧美一级专区| 国产女人aaa级久久久级| 一区二区三区精品| 亚洲一区二区综合| 欧美视频1区| 一区二区三区www| 亚洲图片在线观看| 国产精品久久久久一区二区| 亚洲天堂网在线观看| 亚洲激情一区二区三区| 欧美午夜不卡视频| 亚洲黄色影院| 最新日韩精品| 欧美护士18xxxxhd| 亚洲国产美女| 一本久道久久综合狠狠爱| 欧美理论视频| 一区二区三区蜜桃网| 亚洲欧美视频一区二区三区| 国产精品三上| 欧美在线一二三区| 免费看成人av| 日韩视频欧美视频| 欧美天堂亚洲电影院在线播放| 一区二区免费在线观看| 欧美一区二区在线观看| 国产亚洲毛片在线| 久久久精彩视频| 欧美暴力喷水在线| 日韩午夜黄色| 国产精品丝袜xxxxxxx| 欧美专区中文字幕| 亚洲高清二区| 亚洲男人的天堂在线| 国产一区 二区 三区一级| 玖玖玖国产精品| 中文久久乱码一区二区| 久久天堂国产精品| 91久久国产综合久久| 国产精品国产一区二区| 久久er精品视频| 亚洲美女电影在线| 久久久999精品免费| 日韩亚洲一区二区| 国产欧美综合在线| 欧美国产第一页| 午夜在线一区| 日韩视频久久| 欧美成人伊人久久综合网| 亚洲在线观看视频| 亚洲国产精品va在看黑人| 国产精品久久午夜夜伦鲁鲁| 久久精品一区二区三区中文字幕| 亚洲精品女av网站| 欧美中文字幕视频| 亚洲美女精品久久| 黄色成人片子| 国产精品一区二区女厕厕| 你懂的亚洲视频| 久久国产婷婷国产香蕉| 中国av一区| 亚洲精品一二区| 欧美高清在线播放| 久久久国产精彩视频美女艺术照福利| 99精品视频免费全部在线| 在线看视频不卡| 国产亚洲综合精品|