• <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++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            關于UNIX下的core文件

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

            UNIX下調試程序,如果遇到內存溢出等問題的時候,經常在當前目錄下出現這樣一個文件:core

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

            1.例如調試程序一段名為samp.c 的程序,如下進行調試

            $ cc -g samp.c -o samp

            $ samp

            當程序在運行的時候出現一個

            Bus Error - core dumped

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

                $ 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聯系進程,程序如下:

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

            * looper.c: *

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

                 main()

             

                 {

             

                       int i,x[10];

             

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

             

                 }

            很顯然這是一個死循環程序,先編譯

                 $ cc -g looper.c -o looper

                 $ looper

            當程序運行時,在另一個打開的窗口里用指令 ps -u UserID 獲得進程looperID,

                      PID     TTY      TIME    COMMAND

             

                      68      console   0:04    sh

             

                      467     lft3     10:48    looper

            從而得到進程的ID 467   下面執行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

            現在你可以獲得程序出現問題的位置了。

            以上程序在UNIX AIX4.3下調試通過。

                  

             


            奇米影视7777久久精品| 狠狠综合久久综合中文88| 97香蕉久久夜色精品国产 | 色婷婷久久久SWAG精品| 99久久精品国产一区二区| 国产视频久久| 久久亚洲中文字幕精品有坂深雪| 国产精品久久午夜夜伦鲁鲁| 亚洲伊人久久大香线蕉苏妲己| 色播久久人人爽人人爽人人片aV| 久久国产色av免费看| 久久se精品一区二区| 亚洲精品乱码久久久久久蜜桃| 久久久国产乱子伦精品作者| 精品久久人人妻人人做精品| 欧美精品乱码99久久蜜桃| 国产精品99久久精品| 亚洲精品成人久久久| 精品久久久久久无码专区不卡| 久久精品国产WWW456C0M| 久久精品亚洲一区二区三区浴池 | 久久97久久97精品免视看| 久久精品国产色蜜蜜麻豆| 国产L精品国产亚洲区久久| 亚洲AV无一区二区三区久久 | 久久婷婷五月综合成人D啪| 久久久青草久久久青草| 久久精品国产亚洲AV忘忧草18| 久久久久无码精品| 日本免费久久久久久久网站| 久久综合88熟人妻| 色欲综合久久中文字幕网| 国内精品久久国产| 亚洲综合久久夜AV | 日本精品一区二区久久久| 26uuu久久五月天| 嫩草影院久久99| 亚洲国产二区三区久久| 精品久久香蕉国产线看观看亚洲| 久久久久成人精品无码中文字幕| 东方aⅴ免费观看久久av|