信號 核心轉儲 gdb調試

信號:

         使用kill -l  查看linux中的信號。


        可以從上圖看出linux中一共有62個信號(沒有32,33)。1-31爲普通信號,34-64爲實時信號。我們主要關注前31個信號。每一個信號都有其對應的意義。

1) SIGHUP 本信號在用戶終端連接(正常或非正常)結束時發出, 通常是在終端的控制進程結束時, 通知同一session內的各個作業, 這時它們與控制終端不再關聯.   
2) SIGINT 程序終止(interrupt)信號, 在用戶鍵入INTR字符(通常是Ctrl-C)時發出   
3) SIGQUIT 和SIGINT類似, 但由QUIT字符(通常是Ctrl-\)來控制. 進程在因收到SIGQUIT退出時會產生core文件, 在這個意義上類似於一個程序錯誤信號.   
4) SIGILL 執行了非法指令. 通常是因爲可執行文件本身出現錯誤, 或者試圖執行數據段. 堆棧溢出時也有可能產生這個信號.   
5) SIGTRAP 由斷點指令或其它trap指令產生. 由debugger使用.   
6) SIGABRT 程序自己發現錯誤並調用abort時產生.   
7) SIGIOT 在PDP-11上由iot指令產生, 在其它機器上和SIGABRT一樣.   
8) SIGBUS 非法地址, 包括內存地址對齊(alignment)出錯. eg: 訪問一個四個字長的整數, 但其地址不是4的倍數.   
9) SIGFPE 在發生致命的算術運算錯誤時發出. 不僅包括浮點運算錯誤, 還包括溢出及除數爲0等其它所有的算術的錯誤.   
10) SIGKILL 用來立即結束程序的運行. 本信號不能被阻塞, 處理和忽略.   
11) SIGUSR1 留給用戶使用   
12) SIGSEGV 試圖訪問未分配給自己的內存, 或試圖往沒有寫權限的內存地址寫數據.   
13) SIGUSR2 留給用戶使用   
14) SIGPIPE Broken pipe   
15) SIGALRM 時鐘定時信號, 計算的是實際的時間或時鐘時間. alarm函數使用該信號.   
16) SIGTERM 程序結束(terminate)信號, 與SIGKILL不同的是該信號可以被阻塞和處理. 通常用來要求程序自己正常退出. shell命令kill缺省產生這個信號.   
17) SIGCHLD 子進程結束時, 父進程會收到這個信號.   
18) SIGCONT 讓一個停止(stopped)的進程繼續執行. 本信號不能被阻塞. 可以用一個handler來讓程序在由stopped狀態變爲繼續執行時完成特定的工作. 例如, 重新顯示提示符   
19) SIGSTOP 停止(stopped)進程的執行. 注意它和terminate以及interrupt的區別: 該進程還未結束, 只是暫停執行. 本信號不能被阻塞, 處理或忽略.   
20) SIGTSTP 停止進程的運行, 但該信號可以被處理和忽略. 用戶鍵入SUSP字符時(通常是Ctrl-Z)發出這個信號   
21) SIGTTIN 當後臺作業要從用戶終端讀數據時, 該作業中的所有進程會收到SIGTTIN信號. 缺省時這些進程會停止執行.   
22) SIGTTOU 類似於SIGTTIN, 但在寫終端(或修改終端模式)時收到.   
23) SIGURG 有緊急數據或out-of-band數據到達socket時產生.   
24) SIGXCPU 超過CPU時間資源限制. 這個限制可以由getrlimit/setrlimit來讀取/改變   
25) SIGXFSZ 超過文件大小資源限制.   
26) SIGVTALRM 虛擬時鐘信號. 類似於SIGALRM, 但是計算的是該進程佔用的CPU時間.   
27) SIGPROF 類似於SIGALRM/SIGVTALRM, 但包括該進程用的CPU時間以及系統調用的時間.   
28) SIGWINCH 窗口大小改變時發出.   
29) SIGIO 文件描述符準備就緒, 可以開始進行輸入/輸出操作.   
30) SIGPWR Power failure

當進程異常退出的時候,操作系統會把對應的異常信息寫入進程對應的core文件,即核心轉儲(coredump)。值得注意的是核心轉儲在默認情況下是關閉的(防止反覆存儲佔滿硬盤),如果想要獲得相應的信息需要對其進行設置。

ulimit -a   查看core文件信息 默認文件大小爲0。


ulimit -c  x  修改core文件大小爲x


在linux'編程中我們可以先運行程序再利用核心轉儲文件的裏面的信息快速的對程序進行debug。這叫做事後調試。即先運行收集錯誤信息,然後準確定位錯誤。

寫一個簡單的程序利用核心轉儲文件和gdb進行調試:


首先確保已經對coer文件權限進行了設置,上面已經提到


運行gdb  加載可執行文件 ,加載core文件  可以看出 直接將程序錯誤定位在第七行  顯示除0錯誤。

修改錯誤以後 重新make 產生可執行文件 重複之前步驟顯示


回到程序中去看 其實是對13行的空指針進行了解引用。

修改以後再次make顯示沒有bug了。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章