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

Daly的游戲人生

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

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

不過文章[1]中說明了,替代全局new不是一個好做法. 其實要達到以上兩點目的,筆者認為用valgrind工具鏈就可以了。

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

2.  linux下C的程序可以用wrap的方式(相當(dāng)于python的decorator)
     編譯加上選項:gcc -Wl,-wrap,malloc
     可以做到對malloc這個函數(shù),linker會調(diào)用__wrap_malloc代替之, 若要調(diào)用原來的malloc函數(shù)__real_malloc
     缺點:依賴于編譯器支持; 對c++的new不起作用 --> 不實用
     啟示:這個方法作為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);
     缺點:依賴GNU編譯工具鏈;  容易死循環(huán)(想利用原有malloc,要參考例子中,把原__malloc_hook變量保存起來使用,并恢復(fù)現(xiàn)場)

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

 有時候valgrind的效率是個問題(尤其生產(chǎn)環(huán)境),這種方案有其價值所在, 就是代碼看上去比較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的替代品:
     自己寫一個malloc其實很復(fù)雜,要考慮線程安全等各種問題,性能到頭來可能更差。google 的tcmalloc,  facebook使用的jemalloc.   多線程下性能較好,可以考慮使用。
     缺點:筆者嘗試過。tcmalloc不能正確用valgrind,只能用自帶gperftools(運行中會core)
                 jemalloc可以使用valgrind,不過還沒完全驗證是否都準確。
tcmalloc相關(guān):
    在64位系統(tǒng)上要裝libunwind, 對x86-64架構(gòu)使用還有些問題

源碼包的INSTALL文檔里面也提到了這個問題。
 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位機frame-pointer的影響, 他的profile工具里的backtrace用libunwind這個庫,這個庫又有版本問題,各種囧啊....
筆者試過系統(tǒng)x86-64, freebsd,用靜態(tài)鏈接。實際用了一下,問題很多很折騰,等他fix了再說吧.

windows下可以參考:

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

[2] effective c++條款50:了解new和delete的合理替換時機

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

posted on 2012-07-02 13:01 Daly 閱讀(7525) 評論(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>
            夜夜嗨av一区二区三区网站四季av | 欧美亚洲在线视频| 国产精品视频久久久| 亚洲私拍自拍| 亚洲欧美精品在线观看| 国产日韩久久| 欧美成人官网二区| 欧美激情第4页| 亚洲欧美春色| 久久精品国产一区二区三区免费看 | 最新国产精品拍自在线播放| 亚洲欧洲日韩综合二区| 欧美视频在线一区| 久久精品视频va| 开元免费观看欧美电视剧网站| 亚洲破处大片| 亚洲一级高清| 亚洲国产色一区| 99国产精品99久久久久久粉嫩| 国产精品揄拍500视频| 久久久精品一区二区三区| 免费美女久久99| 午夜伦理片一区| 香蕉国产精品偷在线观看不卡| 亚洲国产婷婷| 亚洲字幕在线观看| 日韩一区二区高清| 久久九九热免费视频| 亚洲少妇在线| 免费成年人欧美视频| 亚洲午夜精品一区二区三区他趣| 欧美在线亚洲一区| 亚洲在线播放| 欧美劲爆第一页| 久久激情视频久久| 欧美人与性动交a欧美精品| 久久精品国产视频| 欧美三级电影网| 免费日韩成人| 国产欧美日韩激情| av不卡在线| 日韩一区二区福利| 欧美1区2区视频| 久久久久高清| 国产精品美女www爽爽爽视频| 亚洲第一黄网| 在线精品视频一区二区| 午夜天堂精品久久久久| 亚洲一区欧美激情| 欧美视频手机在线| 亚洲精品国产精品久久清纯直播| 在线播放一区| 久久精品在线观看| 久久综合成人精品亚洲另类欧美| 国产精品你懂的| 亚洲网友自拍| 亚洲欧美国产高清| 国产精品高潮呻吟久久| 日韩性生活视频| 亚洲午夜av电影| 欧美日韩视频不卡| 一区二区欧美视频| 在线综合亚洲| 欧美日韩一区二区在线观看| 亚洲国产天堂久久综合| 亚洲精品乱码久久久久久日本蜜臀| 久久精品国产在热久久| 久久深夜福利免费观看| 黄色工厂这里只有精品| 久久久91精品国产一区二区三区 | 在线视频亚洲| 欧美日韩一区二区三区在线| 亚洲国产综合在线看不卡| 亚洲精品黄网在线观看| 欧美国产亚洲视频| 99www免费人成精品| 亚洲在线视频免费观看| 国产美女精品免费电影| 午夜一区不卡| 欧美成熟视频| 一本色道久久综合精品竹菊| 欧美日韩日日骚| 午夜在线视频观看日韩17c| 狂野欧美性猛交xxxx巴西| 亚洲韩国日本中文字幕| 欧美日韩国产美| 欧美韩国一区| 亚洲女人小视频在线观看| 国产亚洲精品自拍| 久久一日本道色综合久久| 亚洲人成久久| 久久久国产午夜精品| 亚洲日本欧美日韩高观看| 欧美激情va永久在线播放| 亚洲资源av| 欧美二区在线观看| 亚洲在线一区二区| 在线精品观看| 国产精品中文字幕在线观看| 久久人体大胆视频| 亚洲网站在线播放| 男人的天堂亚洲| 亚洲中无吗在线| 一区二区在线视频| 欧美午夜精品久久久久久浪潮| 久久gogo国模裸体人体| 99天天综合性| 免费成人小视频| 先锋影音一区二区三区| 亚洲精品国产精品国自产观看浪潮 | 国产欧美日韩精品丝袜高跟鞋| 老牛嫩草一区二区三区日本| 中日韩高清电影网| 欧美承认网站| 久久久噜久噜久久综合| 亚洲一区免费在线观看| 亚洲经典在线看| 狠狠综合久久| 国产伦精品一区二区三区四区免费| 欧美肥婆在线| 麻豆久久久9性大片| 性欧美videos另类喷潮| av成人免费观看| 亚洲日本在线观看| 欧美va天堂在线| 久久久精品国产免费观看同学| 亚洲一区二区三区四区五区黄| 亚洲精品一区二区三区99| 亚洲成色999久久网站| 国产午夜精品全部视频在线播放| 国产精品a久久久久| 欧美区在线观看| 欧美日韩成人精品| 欧美激情综合色综合啪啪| 美日韩丰满少妇在线观看| 久久青草欧美一区二区三区| 欧美一级专区免费大片| 亚洲综合电影一区二区三区| 亚洲一区二区在线看| 亚洲一区二区三区四区五区午夜 | 99综合在线| 99在线观看免费视频精品观看| 亚洲国产精品va| 91久久一区二区| 日韩午夜剧场| 一区二区高清视频| 亚洲一区综合| 欧美中文字幕视频| 久久精品二区| 久久青青草原一区二区| 免费不卡亚洲欧美| 欧美激情中文字幕乱码免费| 欧美精品久久99久久在免费线| 欧美激情在线| 欧美日韩中文字幕日韩欧美| 欧美午夜免费电影| 国产亚洲精品久久久| 尤物九九久久国产精品的分类| 亚洲国产欧美一区二区三区久久 | 亚洲欧美日韩电影| 欧美专区日韩专区| 裸体素人女欧美日韩| 欧美黄色影院| 一本色道久久88亚洲综合88| 亚洲欧美日韩国产综合| 久久久久久电影| 欧美精品一区在线播放| 国产精品www.| 黄色成人在线观看| av不卡在线看| 久久黄色网页| 91久久在线| 性色一区二区三区| 欧美成人资源网| 国产精品一区二区三区成人| 很黄很黄激情成人| 一区二区三区导航| 久久久久九九九九| 99精品99| 麻豆免费精品视频| 国产麻豆精品在线观看| 亚洲精品视频在线播放| 久久国产一区二区| 日韩一区二区免费高清| 久久精品中文字幕免费mv| 欧美日韩三区四区| 一区二区三区在线视频播放| 亚洲图片在区色| 模特精品在线| 午夜一区不卡| 欧美亚韩一区| 亚洲精品国偷自产在线99热| 欧美在线国产| 日韩视频在线播放| 久久躁日日躁aaaaxxxx| 国产精品一区二区三区四区五区| 亚洲精品国产视频| 狼人天天伊人久久| 亚洲欧美日韩国产中文| 欧美日韩国产影片|