本文實例講述了linux下基于C語言的信號編程方法。分享給大家供大家參考。具體如下:
#include <stdio.h>#include <unistd.h>#include <stdlib.h>#include <unistd.h>#include <signal.h>void sig_handler(int sig_no, siginfo_t *info, void *ctext){ printf("receive sig_no=%d/n",sig_no); if(sig_no == SIGQUIT){ printf("haha,想退出了嗎?"); }else{ printf("si_signo=%d/n",info->si_signo); printf("si_code =%d/n",info->si_code); printf("si_pid =%d/n",info->si_pid); printf("si_uid =%d/n",info->si_uid); printf("si_status=%d/n",info->si_status); printf("si_utime =%lld/n",info->si_utime); printf("si_stime =%lld/n",info->si_stime); printf("si_value =%d/n",info->si_value); printf("si_addr =0x%x/n",info->si_addr); printf("si_fd =%d/n",info->si_fd); } return ;}/*--------------------常用信號列表----------------------------*///SIGINT ctrl+c //SIGQUIT ctrl+///SIGPIPE 管道破裂//SIGKILL 進程終止,不能被捕獲//SIGHUP shell退出//SIGCHLD 子進程終止信號//SIGFPE 浮點數異常(除以0之類的)//SIGTERM 終止信號(kill pid)int main(int argc ,char **argv){ struct sigaction sa; sa.sa_flags = 0; sa.sa_sigaction = sig_handler; sa.sa_flags |= SA_SIGINFO; //使用sa_sigaction作為回調 //sa.sa_flags |= SA_RESETHAND; //處理函數只會被調用一次,之后被重置 //sa.sa_flags |= SA_NOCLDSTOP; //如果安裝了SIGCLD,子進程不是正常退出,而是被kill掉了,則不會通知 //sa.sa_flags |= SA_NODEFER ; //使對信號的屏蔽無效,即在信號處理函數執行期間仍能發出這個信號 //sa.sa_flags |= SA_RESTART ; //使被信號打斷的系統調用自動重新發起 //sa.sa_flags |= SA_NOCLDWAIT; //使父進程在它的子進程退出時不會收到 SIGCHLD 信號,這時子進程如果退出也不會成為僵尸進程 //安裝信號 if(sigaction(SIGINT,&sa,NULL)==-1) printf("安裝信號失敗/n"); if(sigaction(SIGQUIT,&sa,NULL)==-1) printf("安裝信號失敗/n"); while(1){ sleep(1); } return 0;}/*--------------------------信號編程相關結構體----------------------------------*/ // struct sigaction { // void (*sa_handler)(int); // void (*sa_sigaction)(int, siginfo_t *, void *); // sigset_t sa_mask; // int sa_flags; // void (*sa_restorer)(void); // }// siginfo_t {// int si_signo; /* Signal number */// int si_errno; /* An errno value */// int si_code; /* Signal code */// pid_t si_pid; /* Sending process ID */// uid_t si_uid; /* Real user ID of sending process */// int si_status; /* Exit value or signal */// clock_t si_utime; //User time consumed // clock_t si_stime; /* System time consumed */// sigval_t si_value; /* Signal value */// int si_int; /* POSIX.1b signal */// void * si_ptr; /* POSIX.1b signal */// void * si_addr; /* Memory location which caused fault */// int si_band; /* Band event */// int si_fd; /* File descriptor */// }// 信號 值 動作 解釋// SIGHUP 1 終端線路掛斷// SIGINT 2 Term 鍵盤輸入的中斷命令,從終端輸入 Ctrl-C 時發生// SIGQUIT 3 Core 鍵盤輸入的退出命令// SIGILL 4 Core 錯誤指令// SIGABRT 6 Core abort(3)發出的中止信號// SIGFPE 8 Core 浮點數異常// SIGKILL 9 Term KILL信號// SIGSEGV 11 Core 非法內存訪問// SIGPIPE 13 Term 管道斷開// SIGALRM 14 Term alarm(2)發出的中止信號// SIGTERM 15 Term 強制中止信號// SIGUSR1 30,10,16 Term 用戶自定義信號1// SIGUSR2 31,12,17 Term 用戶自定義信號2// SIGCHLD 20,17,18 Ign 子進程中止信號// SIGCONT 19,18,25 Cont 繼續執行一個停止的進程// SIGSTOP 17,19,23 Stop 非終端來的停止信號// SIGTSTP 18,20,24 Stop 終端來的停止信號// SIGTTIN 21,21,26 Stop 后臺進程讀終端// SIGTTOU 22,22,27 Stop 后臺進程寫終端
希望本文所述對大家的C語言程序設計有所幫助。
新聞熱點
疑難解答
圖片精選