• <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>

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運(yùn)轉(zhuǎn),開心的工作
            簡單、開放、平等的公司文化;尊重個(gè)性、自由與個(gè)人價(jià)值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理


            一種定位內(nèi)存泄露的方法(Linux)
            .
            ?分類: C/C++Linux2010-05-16 18:35611人閱讀評(píng)論(0)收藏舉報(bào)


            目的:
            ?
            本文是《一種定位內(nèi)存泄露的方法(Solaris)》對(duì)應(yīng)的Linux版本,調(diào)試器使用gdb。主要介紹實(shí)例部分。其他請(qǐng)見《一種定位內(nèi)存泄露的方法(Solaris)》。
            ?
            實(shí)例:
            ?
            模擬new失敗的程序:
            ?
            #include <stdexcept>
            ?
            class ABC
            ?
            {
            ?
            public:
            ?
            ??????? virtual ~ABC(){}
            ?
            ??????? int i;
            ?
            ??????? int j;
            ?
            };
            ?
            ?
            ?
            void f()
            ?
            {
            ?
            ??????? for (int i = 0; i < 1000; ++i)
            ?
            ??????? {
            ?
            ??????????????? ABC* p = new ABC;
            ?
            ??????? }
            ?
            ??????? throw std::bad_alloc();
            ?
            }
            ?
            ?
            ?
            int main()
            ?
            {
            ?
            ??????? f();
            ?
            ??????? return 0;
            ?
            }
            ?
            1) 編譯運(yùn)行此段代碼。產(chǎn)生一個(gè)core文件
            ?
            2) 用gdb打開這個(gè)core文件:
            ?
            gdb a.out core
            ?
            (gdb) run
            ?
            Starting program: /test/new_fail/a.out

            terminate called after throwing an instance of 'std::bad_alloc'
            ?
            ? what():? std::bad_alloc
            ?
            ?
            ?
            Program received signal SIGABRT, Aborted.
            ?
            0x00007ffff733f645 in raise () from /lib64/libc.so.6
            ?
            (gdb) info proc
            ?
            process 10683
            ?
            cmdline = '/test/new_fail/a.out'
            ?
            cwd = '/test/new_fail'
            ?
            exe = '/test/new_fail/a.out'
            ?
            (gdb) shell pmap 10683
            ?
            10683: a.out
            ?
            START?????????????? SIZE???? RSS???? PSS?? DIRTY??? SWAP PERM MAPPING
            ?
            0000000000400000????? 4K????? 4K????? 4K????? 0K????? 0K r-xp /test/new_fail/a.out
            ?
            0000000000600000????? 4K????? 4K????? 4K????? 4K????? 0K r--p /test/new_fail/a.out
            ?
            0000000000601000????? 4K????? 4K????? 4K????? 4K????? 0K rw-p /test/new_fail/a.out
            ?
            0000000000602000??? 132K???? 32K???? 32K???? 32K????? 0K rw-p [heap]
            ?
            …(略)
            ?
            Total:??????????? 11468K?? 1048K??? 684K??? 180K????? 0K
            ?
            ?
            ?
            360K writable-private, 11108K readonly-private, 0K shared, and 1048K referenced
            ?
            ?
            ?
            可以看到heap空間的起始地址是0x0000000000602000,共132K字節(jié),即132*1024=135168字節(jié)。
            ?
            3) 因?yàn)槭?4位應(yīng)用程序,所以指針占8字節(jié)。所以需要遍歷的指針個(gè)數(shù)為135168/8=16896。
            ?
            4) 將結(jié)果輸出到日志文件gdb.txt中:
            ?
            (gdb) set height 0
            ?
            (gdb) set logging on
            ?
            Copying output to gdb.txt.
            ?
            (gdb) x/16896a 0x0000000000602000
            ?
            gdb.txt的內(nèi)容:
            ?
            0x602000:?????? 0x0???? 0x21
            ?
            0x602010:?????? 0x400b30 <_ZTV3ABC+16>? 0x0
            ?
            0x602020:?????? 0x0???? 0x21
            ?
            0x602030:?????? 0x400b30 <_ZTV3ABC+16>? 0x0
            ?
            ….
            ?
            5) 過濾gdb.txt:
            ?
            awk '{print $2"/n"$3}' gdb.txt|c++filt|grep vtable>gdb_vtable.txt
            ?
            gdb_vtable.txt的內(nèi)容為:
            ?
            <vtable for ABC+16>
            ?
            <vtable for ABC+16>
            ?
            <vtable for ABC+16>
            ?
            <vtable for ABC+16>
            ?
            ….
            ?
            6) 將gdb_vtable.txt的內(nèi)容導(dǎo)入到SQLServer中(如果記錄不多,可以用Excel代替)。表名為gdb_vtable,第一列Col001為符號(hào)。對(duì)其分組求和:
            ?
            select Col001, count(1) quantity from gdb_vtable
            ?
            group by Col001
            ?
            order by quantity desc
            ?
            結(jié)果為:
            ?
            Col001??????????????????????????????????????????????????????????????????????????????????? quantity
            ?
            <vtable for ABC+16>????????????????????????????????????????????????????????????? 1000
            ?
            <vtable for std::bad_alloc@@GLIBCXX_3.4+16>??????????????? 1
            ?
            可知core里有1000個(gè)ABC,遍歷使用ABC的代碼,可知存在泄漏。

            青青草国产成人久久91网| 一本久久知道综合久久| 久久久久国产精品嫩草影院| 日韩精品久久久久久久电影| 久久精品人人做人人妻人人玩| 2021精品国产综合久久| 久久精品中文字幕大胸| 94久久国产乱子伦精品免费| 国产亚洲美女精品久久久2020| 婷婷综合久久中文字幕| 无码人妻久久久一区二区三区| 国内精品久久久久久久影视麻豆| 亚洲精品乱码久久久久久按摩 | 国产亚洲精品美女久久久| 久久精品中文字幕有码| 久久国产高潮流白浆免费观看| 无码8090精品久久一区| 久久成人精品| 久久精品国产半推半就| 久久99精品国产自在现线小黄鸭| 国产精品久久久久久福利漫画 | 久久国产乱子伦精品免费强| 久久99精品免费一区二区| 国产亚洲欧美成人久久片 | 狠狠综合久久综合中文88 | 久久久久久久精品妇女99 | 国产精品久久久久久搜索| 亚洲va中文字幕无码久久不卡| 久久久亚洲AV波多野结衣| 久久久国产视频| 国产精品久久久久久久久软件| 中文国产成人精品久久亚洲精品AⅤ无码精品 | 国产成人无码精品久久久久免费 | 久久亚洲国产成人影院| 欧美久久亚洲精品| 亚洲伊人久久成综合人影院 | 久久无码人妻一区二区三区| 一本色道久久88—综合亚洲精品| 热99RE久久精品这里都是精品免费| 精品人妻伦九区久久AAA片69| 偷窥少妇久久久久久久久|