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

            Prayer

            在一般中尋求卓越
            posts - 1256, comments - 190, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            關(guān)于UNIX下的core文件

            Posted on 2008-10-27 12:42 Prayer 閱讀(459) 評論(0)  編輯 收藏 引用 所屬分類: LINUX/UNIX/AIX
             

            UNIX下調(diào)試程序,如果遇到內(nèi)存溢出等問題的時候,經(jīng)常在當(dāng)前目錄下出現(xiàn)這樣一個文件:core

                用指令>ls –l 可以發(fā)現(xiàn),core是一個很大的文件,動輒上百M,很是耗費(fèi)硬盤空間,所以一般我們都會及時將它清除掉,從而很少去關(guān)注它的真正內(nèi)涵。其實(shí)core中放置的是執(zhí)行進(jìn)程的內(nèi)存映像,其中的提示信息core dump就是信息轉(zhuǎn)儲的意思,在調(diào)試一個有問題的程序時它經(jīng)常是很起作用的。下面我們就來探討一下,如何有效的利用這個core文件來調(diào)試我們的代碼。

            1.例如調(diào)試程序一段名為samp.c 的程序,如下進(jìn)行調(diào)試

            $ cc -g samp.c -o samp

            $ samp

            當(dāng)程序在運(yùn)行的時候出現(xiàn)一個

            Bus Error - core dumped

            的提示,現(xiàn)在core生成了,為了獲得錯誤出現(xiàn)的位置,輸入

                $ dbx samp

            然后我們會得到以下提示

                Type 'help' for help.

                reading symbolic information ...     reading symbolic information . . . [

             

                 using memory image in core]

             

                   25   x[i] = 0;

             

                 (dbx) quit

            2.下面這個例子將要闡述怎么用dbx聯(lián)系進(jìn)程,程序如下:

            /***********

            * looper.c: *

            ************/

                 main()

             

                 {

             

                       int i,x[10];

             

                       for (i = 0; i < 10;);

             

                 }

            很顯然這是一個死循環(huán)程序,先編譯

                 $ cc -g looper.c -o looper

                 $ looper

            當(dāng)程序運(yùn)行時,在另一個打開的窗口里用指令 ps -u UserID 獲得進(jìn)程looperID,

                      PID     TTY      TIME    COMMAND

             

                      68      console   0:04    sh

             

                      467     lft3     10:48    looper

            從而得到進(jìn)程的ID 467   下面執(zhí)行dbx

             $ dbx -a 467

            Waiting to attach to process 467...

            Successfully attached to looper

            Type 'help' for help.

            reading symbolic information ...

            stopped in main at line 5

                5           for (i = 0; i < 10;);

            (dbx) quit

            現(xiàn)在你可以獲得程序出現(xiàn)問題的位置了。

            以上程序在UNIX AIX4.3下調(diào)試通過。

                  

             


            久久精品国内一区二区三区| 精品久久久久久无码国产| 一本久道久久综合狠狠躁AV| 少妇被又大又粗又爽毛片久久黑人| 欧美久久久久久精选9999| 色狠狠久久综合网| 亚洲va久久久噜噜噜久久天堂| 国产精品视频久久| 色婷婷久久久SWAG精品| 国产成年无码久久久久毛片| 精品久久久久国产免费| 久久精品一本到99热免费| 国产成人精品久久亚洲| 中文无码久久精品| 国产精品一区二区久久精品无码| 中文字幕精品久久| 99久久精品免费看国产一区二区三区| 国内精品久久久久影院老司| 94久久国产乱子伦精品免费| 亚洲国产天堂久久综合| 久久亚洲精品视频| 久久精品亚洲日本波多野结衣| 久久激情五月丁香伊人| 亚洲va久久久噜噜噜久久男同| 久久国产免费直播| 天天爽天天爽天天片a久久网| 久久人人爽人人人人片av| 丰满少妇人妻久久久久久4| 色综合久久中文字幕无码| 伊人久久大香线蕉成人| 久久久WWW成人免费毛片| 99热都是精品久久久久久| 2021久久国自产拍精品| 久久精品中文騷妇女内射| 久久婷婷激情综合色综合俺也去| 亚洲日韩欧美一区久久久久我| 久久影视综合亚洲| 久久99亚洲综合精品首页| 久久99精品国产麻豆不卡| 精品久久久久久无码免费| 国产精品VIDEOSSEX久久发布|