這篇文章主要介紹了linux下基于C語言的信號編程,實例分析了信號量的基本使用技巧與相關概念,具有一定參考借鑒價值,需要的朋友可以參考下
本文實例講述了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語言程序設計有所幫助。
新聞熱點
疑難解答