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

Daly的游戲人生

替代系統malloc/new--選擇合適的內存跟蹤方案

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

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

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

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

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

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

源碼包的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這個庫,這個庫又有版本問題,各種囧啊....
筆者試過系統x86-64, freebsd,用靜態鏈接。實際用了一下,問題很多很折騰,等他fix了再說吧.

windows下可以參考:

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

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

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

posted on 2012-07-02 13:01 Daly 閱讀(7522) 評論(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>
            久久视频一区二区| 91久久在线播放| 国产精品久久久久久久电影| 国产乱码精品一区二区三区忘忧草 | 91久久中文| 日韩一级片网址| 老妇喷水一区二区三区| 欧美日韩一本到| 尤物网精品视频| 亚洲综合国产精品| 欧美国产丝袜视频| 欧美在线视频日韩| 国产精品视频内| 99re在线精品| 欧美福利电影网| 久久精品五月婷婷| 国产视频亚洲精品| 欧美亚洲网站| av成人免费观看| 欧美激情一区二区三区| 在线观看欧美一区| 久久久精品网| 亚洲一区二区三区乱码aⅴ蜜桃女| 欧美高清在线一区二区| 亚洲第一精品久久忘忧草社区| 午夜在线成人av| 中日韩男男gay无套| 欧美日韩999| 亚洲最新色图| 亚洲激情视频| 你懂的成人av| 亚洲茄子视频| 亚洲国产高清视频| 久久综合国产精品台湾中文娱乐网| 国产一区在线播放| 欧美一区二区三区免费观看视频 | 在线精品视频一区二区三四| 亚洲一区不卡| 亚洲欧洲一级| 蜜桃av噜噜一区| 久久人人精品| 最新精品在线| 亚洲国产精品久久久久秋霞不卡| 免费不卡中文字幕视频| 亚洲三级视频在线观看| 亚洲国产小视频| 欧美精品99| 亚洲一区制服诱惑| 一区二区激情小说| 国产精品久久久久久久久婷婷 | 国产日韩高清一区二区三区在线| 亚洲欧美大片| 亚洲一区精品视频| 国产一区免费视频| 欧美本精品男人aⅴ天堂| 噜噜噜在线观看免费视频日韩 | 国产精品久久久久久久午夜片| 亚洲一区二区三区在线看| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 国内偷自视频区视频综合| 欧美在线视频一区二区三区| 午夜激情久久久| 极品尤物一区二区三区| 欧美激情一区三区| 欧美日韩中文另类| 欧美在线视频免费播放| 麻豆成人综合网| 亚洲精品视频在线播放| 久久综合伊人77777蜜臀| 久久午夜精品一区二区| av成人激情| 久久精品夜色噜噜亚洲aⅴ| 亚洲国产精品尤物yw在线观看| 亚洲精品日韩在线| 国产视频亚洲| 日韩午夜精品视频| 国产视频久久久久| 亚洲一区二区三区精品在线观看| 在线综合欧美| 欧美www视频| 欧美成人免费网| 黄色亚洲精品| 久久久xxx| 久久色在线观看| 黄页网站一区| 欧美亚洲自偷自偷| 欧美中文在线观看国产| 国产精品免费一区二区三区在线观看| 亚洲毛片在线看| 亚洲一区二区高清视频| 欧美日韩国产成人在线| 欧美在线视频观看免费网站| 欧美激情视频给我| 欧美激情 亚洲a∨综合| 亚洲第一色在线| 久久久欧美精品| 牛牛国产精品| 亚洲欧洲一区二区在线观看| 欧美.日韩.国产.一区.二区| 欧美福利在线| 日韩午夜激情av| 欧美日韩免费在线观看| 99国产精品视频免费观看一公开 | 欧美好吊妞视频| 91久久中文| 欧美日韩国产精品自在自线| 最新中文字幕亚洲| 亚洲视频在线观看免费| 欧美华人在线视频| 一本色道综合亚洲| 久久国产免费看| 亚洲高清一区二区三区| 欧美极品影院| 亚洲嫩草精品久久| 蜜桃精品一区二区三区| 亚洲精品中文在线| 国产精品黄色在线观看| 欧美淫片网站| 亚洲国产你懂的| 午夜精品久久久久久久| 在线不卡视频| 欧美日韩精品欧美日韩精品一| 国产精品99久久久久久久女警| 伊人久久久大香线蕉综合直播 | 午夜久久黄色| 欧美另类videos死尸| 在线视频日韩精品| 久久久国产一区二区| 91久久线看在观草草青青| 欧美午夜激情小视频| 欧美一区三区二区在线观看| 欧美 日韩 国产在线| 99国产精品国产精品毛片| 国产精品扒开腿做爽爽爽软件| 欧美一区二区三区另类| 91久久久精品| 久久精品免费电影| 99视频超级精品| 一区二区视频免费完整版观看| 欧美日本三区| 久久免费的精品国产v∧| 夜夜嗨av色综合久久久综合网| 久久一日本道色综合久久| 中国亚洲黄色| 亚洲国产va精品久久久不卡综合| 国产精品xxxxx| 欧美国产欧美亚州国产日韩mv天天看完整| 亚洲一区二区成人在线观看| 亚洲第一中文字幕在线观看| 久久精品毛片| 性久久久久久久久| 在线亚洲免费| 99精品欧美一区二区三区综合在线| 尤物yw午夜国产精品视频明星| 国产精品久久婷婷六月丁香| 欧美国产视频在线观看| 久久视频精品在线| 欧美亚洲综合网| 亚洲欧美清纯在线制服| 在线亚洲+欧美+日本专区| 99在线热播精品免费99热| 国产一区二区在线免费观看| 国产精品v日韩精品v欧美精品网站| 老司机精品视频网站| 欧美影视一区| 欧美在线1区| 午夜精品视频网站| 亚洲一区亚洲| 亚洲在线观看免费视频| 中日韩高清电影网| 一区二区三区四区国产精品| 亚洲日本激情| 亚洲免费成人av| 亚洲另类在线一区| 亚洲日本欧美| 亚洲人成高清| 亚洲精选成人| 一区二区高清视频| 亚洲视频综合在线| 亚洲综合成人婷婷小说| 亚洲影院在线| 亚洲欧美日韩在线| 欧美一区二区三区免费视频| 久久成人国产精品| 久久人体大胆视频| 美女精品在线| 欧美精品综合| 国产精品www网站| 国产视频自拍一区| 尤物九九久久国产精品的分类| 亚洲福利视频网站| 亚洲最新视频在线播放| 亚洲一区精彩视频| 欧美一级在线播放| 久久这里只有| 亚洲国产精品精华液2区45| 亚洲精品国产欧美| 亚洲欧美一区二区三区久久| 久久久精品2019中文字幕神马| 欧美成人激情在线|