本文實例講述了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 浮點數(shù)異常(除以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作為回調(diào) //sa.sa_flags |= SA_RESETHAND; //處理函數(shù)只會被調(diào)用一次,,之后被重置 //sa.sa_flags |= SA_NOCLDSTOP; //如果安裝了SIGCLD,子進程不是正常退出,,而是被kill掉了,,則不會通知 //sa.sa_flags |= SA_NODEFER ; //使對信號的屏蔽無效,,即在信號處理函數(shù)執(zhí)行期間仍能發(fā)出這個信號 //sa.sa_flags |= SA_RESTART ; //使被信號打斷的系統(tǒng)調(diào)用自動重新發(fā)起 //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; } /*--------------------------信號編程相關(guān)結(jié)構(gòu)體----------------------------------*/ // 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 時發(fā)生 // SIGQUIT 3 Core 鍵盤輸入的退出命令 // SIGILL 4 Core 錯誤指令 // SIGABRT 6 Core abort(3)發(fā)出的中止信號 // SIGFPE 8 Core 浮點數(shù)異常 // SIGKILL 9 Term KILL信號 // SIGSEGV 11 Core 非法內(nèi)存訪問 // SIGPIPE 13 Term 管道斷開 // SIGALRM 14 Term alarm(2)發(fā)出的中止信號 // 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 繼續(xù)執(zhí)行一個停止的進程 // SIGSTOP 17,19,23 Stop 非終端來的停止信號 // SIGTSTP 18,20,24 Stop 終端來的停止信號 // SIGTTIN 21,21,26 Stop 后臺進程讀終端 // SIGTTOU 22,22,27 Stop 后臺進程寫終端 |
|
來自: 心不留意外塵 > 《task sys》