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语言程序设计有所帮助。

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值