linux c语言 信号,linux下基于C语言的信号编程实例
搜索熱詞
本文實例講述了linux下基于C語言的信號編程方法。分享給大家供大家參考。具體如下:
#include
#include
#include
#include
#include
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,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語言程序設計有所幫助。
總結
如果覺得編程之家網站內容還不錯,歡迎將編程之家網站推薦給程序員好友。
本圖文內容來源于網友網絡收集整理提供,作為學習參考使用,版權屬于原作者。
總結
以上是生活随笔為你收集整理的linux c语言 信号,linux下基于C语言的信号编程实例的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 揭秘x99主板内存插槽数,让你的电脑性能
- 下一篇: 英睿达VS金士顿内存条:性能稳定对比,哪