首页 > 编程 > C > 正文

linux下基于C语言的信号编程实例

2020-01-26 15:00:50
字体:
来源:转载
供稿:网友

本文实例讲述了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语言程序设计有所帮助。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选