Linux信号透彻分析理解与各种实例讲解( 四 )
sigqueue函数类似于kill,也是一个进程向另外一个进程发送信号的 。
但它比kill函数强大 。
第一个参数指定目标进程的pid.
第二个参数是一个信号代码 。
第三个参数是一个共用体 , 每次只能使用一个 , 用来进程发送信号传递的数据 。
或者传递整形数据 , 或者是传递指针 。
发送的数据被sa_sigaction所指示的函数的siginfo_t结构体中的si_ptr或者是si_int所接收 。
sigpending的用法
sigpending(sigset_t set);
这个函数的作用是返回未决的信号到信号集set中 。 即未决信号集 , 未决信号集不仅包括被阻塞的信号 , 也可能包括已经到达但没有被处理的信号 。
示例1: sigaction函数的用法
struct sigaction {void (*sa_handler)(int);void (*sa_sigaction)(int,siginfo_t*,void*);sigset_t sa_mask;int sa_flags;void (*sa_restorer)(void);}
运行结果:[root@localhost C]# ./s2signal 1 handler is : using default handersignal 2 handler is : 8048437signal 3 handler is : using default handersignal 4 handler is : using default handersignal 5 handler is : using default handersignal 6 handler is : using default handersignal 7 handler is : using default handersignal 8 handler is : using default handersignal 9 handler is : using default handersignal 10 handler is : using default handersignal 11 handler is : using default handerxxxxx解释:
sigaction(i,NULL,
signal_set(
由于act为NULL,那么oldact保存的是当前信号的行为 , 当前的第二个信号的行为是执行自定义的处理程序 。
当按下CTRL+C时会执行信号处理程序 , 输出xxxxxx , 再按一下CTRL+C会停止,是由于SA_RESETHAND恢复成默认的处理模式 , 即终止程序 。
如果没有设置SA_NODEFER,那么在处理函数执行过程中按一下CTRL+C将会被阻塞 , 那么程序会停在那里 。
示例2: sigqueue向本进程发送数据的信号
#include#include#include#include#includevoid myhandler(int signo,siginfo_t *si,void *ucontext);int main(){union sigval val;//定义一个携带数据的共用体struct sigaction oldact,act;act.sa_sigaction=myhandler;act.sa_flags=SA_SIGINFO;//表示使用sa_sigaction指示的函数 , 处理完恢复默认 , 不阻塞处理过程中到达下在被处理的信号//注册信号处理函数sigaction(SIGUSR1,char data[100];int num=0;while(num<10){sleep(2);printf("等待SIGUSR1信号的到来/n");sprintf(data,"%d",num++);val.sival_ptr=data;sigqueue(getpid(),SIGUSR1,val);//向本进程发送一个信号}}void myhandler(int signo,siginfo_t *si,void *ucontext){printf("已经收到SIGUSR1信号/n");printf("%s/n",(char*)(si->si_ptr));}
程序执行的结果是:
等待SIGUSR1信号的到来已经收到SIGUSR1信号0等待SIGUSR1信号的到来已经收到SIGUSR1信号1等待SIGUSR1信号的到来已经收到SIGUSR1信号2等待SIGUSR1信号的到来已经收到SIGUSR1信号3等待SIGUSR1信号的到来已经收到SIGUSR1信号4等待SIGUSR1信号的到来已经收到SIGUSR1信号5等待SIGUSR1信号的到来已经收到SIGUSR1信号6等待SIGUSR1信号的到来已经收到SIGUSR1信号7等待SIGUSR1信号的到来已经收到SIGUSR1信号8等待SIGUSR1信号的到来已经收到SIGUSR1信号9
解释: 本程序用sigqueue不停的向自身发送信号,并且携带数据 , 数据被放到处理函数的第二个参数siginfo_t结构体中的si_ptr指针 , 当num<10时不再发 。
一般而言 , sigqueue与sigaction配合使用 , 而kill与signal配合使用 。
示例3: 一个进程向另外一个进程发送信号 , 并携带信息
推荐阅读
- 近期浙江引来这么多重磅级“帮手”传递什么信号?
- Linux Kernel 5.10.5发布:禁用FBCON加速滚动特性
- Linux 5.11开始围绕PCI Express 6.0进行早期准备
- Fedora正在寻求协助 希望加快Linux 5.10 LTS内核测试进度
- iPhone 12信号差真实原因曝光:不是基带问题
- Linux Mint 20.1 Ulyssa稳定版已确定延期至2021年初发布
- 英特尔Xe GPU在Linux 5.11上的性能表现不错
- iPhone12 重现iPhone 7“信号门”,但库克沉默
- MIPS架构厂商日渐式微 Linux报告其漏洞遭遇困难
- 将要报废的手机会出现这三个信号,你出现了吗?