函数sigqueue

一、函数sigqueue

sigqueue函数原型:

函数作用:新的发送信号系统调用,主要是针对实时信号提出的支持信号带有参数,与函数sigaction()配合使用

int sigqueue(pid_t pid, int signo, const union sigval value);

分析:

  • 第一个参数: 指定接收信号的进程id
  • 第二个参数:确定即将发送的信号
  • 第三个参数:是一个联合结构体union sigval,指定了信号传递的参数,即通常所说的4字节值 

二、程序清单

1. 测试代码:

发送端程序代码:

#include <string.h>
#include <signal.h>
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>void handler(int, siginfo_t *, void*);int main(int argc, char *argv[])
{printf("I'm %d\n", getpid());struct sigaction act;act.sa_sigaction = handler;sigemptyset(&act.sa_mask);act.sa_flags = SA_SIGINFO;if(sigaction(SIGINT, &act, NULL) < 0) {perror("sigaction error");exit(0);}for(; ;)pause();return 0;
}void handler(int sig, siginfo_t *info, void *ctx)
{printf("recv a sig = %d data = %d data = %d\n", sig, info->si_value.sival_int, info->si_int);
}

接收端程序代码:

#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <signal.h>
#include <unistd.h>int main(int argc, char *argv[])
{if(argc != 2) {fprintf(stderr, "Usage %s pid\n", argv[0]);exit(0);}pid_t pid = atoi(argv[1]);union sigval v;v.sival_int = 100;sigqueue(pid, SIGINT, v);sleep(3);return 0;}

输出结果

发送端:

接收端:

 

2. 测试代码:

发送端程序:

#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <signal.h>
#include <unistd.h>int main(int argc, char *argv[])
{if(argc != 2) {fprintf(stderr, "Usage %s pid\n", argv[0]);exit(0);}pid_t pid = atoi(argv[1]);union sigval v;v.sival_int = 100;sigqueue(pid, SIGINT, v);sigqueue(pid, SIGINT, v);sigqueue(pid, SIGINT, v);sigqueue(pid, SIGRTMIN, v);sigqueue(pid, SIGRTMIN, v);sigqueue(pid, SIGRTMIN, v);sleep(3);kill(pid, SIGUSR1);return 0;    
}

接收端程序:

#include <string.h>
#include <signal.h>
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>void handler(int sig);int main(int argc, char *argv[])
{printf("I'm %d\n", getpid());struct sigaction act;act.sa_sigaction = handler;sigemptyset(&act.sa_mask);act.sa_flags = 0;sigset_t s;sigemptyset(&s);sigaddset(&s, SIGINT);sigaddset(&s, SIGRTMIN);sigprocmask(SIG_BLOCK, &s, NULL);if(sigaction(SIGINT, &act, NULL) < 0) {perror("sigaction error");exit(0);}if(sigaction(SIGRTMIN, &act, NULL) < 0) {perror("sigaction error");exit(0);}if(sigaction(SIGUSR1, &act, NULL) < 0) {perror("sigaction error");exit(0);}for(; ;)pause();return 0;
}void handler(int sig)
{if(sig == SIGINT || sig == SIGRTMIN) printf("recv a sig = %d\n", sig);else if(sig == SIGUSR1){sigset_t s;sigemptyset(&s);sigaddset(&s, SIGINT);sigaddset(&s, SIGRTMIN);sigprocmask(SIG_UNBLOCK, &s, NULL);		}
}

输出结果:

发送端:

接收端:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/385562.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【好文推荐】mysql创建数据库语句utf-8

性能调优 影响MySQLServer 性能的相关因素 商业需求对性能的影响系统架构及实现对性能的影响Query语句对系统性能的影响Schema设计对系统的性能影响硬件环境对系统性能的影响 MySQL 数据库锁定机制 MySQL锁定机制简介各种锁定机制分析合理利用锁机制优化MySQL MySQL数据库Qu…

函数setjump和longjmp

一、主要函数应用 函数setjmp 原型&#xff1a; #include <setjmp.h> Int setjmp(jmp_buf env);返回值&#xff1a;若直接调用则返回0&#xff0c;若从longjmp调用返回则返回非0值的longjmp中的val值 分析&#xff1a; 返回值&#xff1a;若直接调用则返回0&#xf…

java接口的定义与实现实验报告,赶紧收藏备战金三银四!

一、对Kafka的认识 1.Kafka的基本概念 2.安装与配置 3.生产与消费 4.服务端参数配置 二、生产者 1.客户端开发 2.原理分析 3.重要的生产者参数 三、消费者 1.消费者与消费组 2.客户端开发 四、主题与分区 1.主题的管理 2.初识KafkaAdminCilent 3.分区的管理 4.如何…

函数sigsetjump和siglongjump

摘要&#xff1a; 在信号处理函数执行时&#xff0c;会阻塞当前信号。当信号处理函数返回时&#xff0c;系统会帮我们把刚刚阻塞的信号再从阻塞集中移除。一、 临时阻塞特性 当执行信号处理函数的时候&#xff0c;会临时将当前被处理信号阻塞。为了能说明问题&#xff0c;采用…

java操作word文档,深度解析,值得收藏

Java虚拟机内存模型 Java虚拟机内存模型中定义的访问操作与物理计算机处理的基本一致&#xff01; Java中通过多线程机制使得多个任务同时执行处理&#xff0c;所有的线程共享JVM内存区域main memory&#xff0c;而每个线程又单独的有自己的工作内存&#xff0c;当线程与内存区…

java支付模块架构,涨薪7K!

Java基础 JDK 和 JRE 有什么区别&#xff1f; 和 equals 的区别是什么&#xff1f;两个对象的 hashCode()相同&#xff0c;则 equals()也一定为 true&#xff0c;对吗&#xff1f;final 在 java 中有什么作用&#xff1f;java 中的 Math.round(-1.5) 等于多少&#xff1f;Stri…

【信号】SIGCHLD信号

一、SIGCHLD信号 1. SIGCHLD简介 SIGCHLD的产生条件&#xff1a; 子进程终止子进程接收到SIGSTOP信号停止时子进程处于停止状态&#xff0c;接收到SIGCONT后唤醒注意&#xff1a;通过signal(SIGCHLD, SIG_IGN)通知内核对子进程的结束不关心&#xff0c;由内核回收。如果不想让…

java改错题技巧,看这篇文章准没错!

阿里 mq 消息可靠性,幂等如何保证分布式锁的实现方案比较,为什么选择 zookeeper, zookeeper 一致性协议原理线程池参数,阻塞队列实现一致性 Hash解决什么问题, 如何实现? 虚拟节点的作用?Java 锁的实现方式, 比较? AQS实现原理?公平非公平实现原理?CAS 实现原理volatile 实…

函数stat、fstat、fstatat和lstat

一、主要函数应用 #include <sys/stat.h> int stat(const char *path, struct stat *buf); int fstat(int fd, struct stat *buf) int lstat(const char *path, struct stat *buf); int fstat(int fd, const char *path, struct stat *buf, int flag);参数&#xff1a;…

java教程pdf下载百度云,面试题+笔记+项目实战

一面问题&#xff1a;MySQLRedisKafka线程算法 mysql知道哪些存储引擎&#xff0c;它们的区别mysql索引在什么情况下会失效mysql在项目中的优化场景&#xff0c;慢查询解决等mysql有什么索引&#xff0c;索引模型是什么B-树与B树的区别&#xff1f;为什么不用红黑树mysql主从同…

函数mkdir、mkdirat和emdir

一、目录的权限位 目录的权限位&#xff0c;至少要设置一个执行许可位。即 rwx 中的那个 x 位。如果不设置&#xff0c;就没办法使用 cd 命令进入目录&#xff0c;也无法读取目录下的文件内容。所以&#xff0c;这个位是必须的。目录的写权限位。如果未设置写权限位(w 位)&…

java教程传智播客,面试真题解析

01 阿里中间件&#xff08;四面&#xff0c;Java岗&#xff09; 1.1 Java中间件一面 技术一面考察范围 重点问了Java线程锁&#xff1a;synchronized 和ReentrantLock相关的底层实现 线程池的底层实现以及常见的参数 数据结构基本都问了一遍&#xff1a;链表、队列等 Java内存…

java教程百度文库,成功拿到offer

正文 现在市面上的算法资料也五花八门&#xff0c;种类繁多&#xff0c;小编也整理了一份不同于市面且有意思的算法资料&#xff0c;不能说多全面&#xff0c;但是是小编花了很长时间整理归纳出来的&#xff0c;自我感觉还行。分享给同事及群里反响都不错&#xff0c;所以小编…

java数字排序代码,进阶加薪全靠它!

数据库 2.1 池化技术&#xff1a;如何减少频繁创建数据库连接的性能损耗&#xff1f;2.2 数据库优化方案&#xff08;一&#xff09;&#xff1a;查询请求增加时&#xff0c;如何做主从分离&#xff1f;2.3 数据库优化方案&#xff08;二&#xff09;&#xff1a;写入数据量增…

函数umask

umask函数原型&#xff1a; #include <sys/stat.h> mode_t umask(mode_t mask); 分析&#xff1a; 在进程创建一个新的文件或目录时&#xff0c;如调用open函数创建一个新文件&#xff0c;新文件的实际存取权限是mode与umask按照 mode&~umask运算以后的结果。umask…

java数据分析库,威力加强版

美团技术一面20分钟 晚7点&#xff0c;因为想到下周一才面试&#xff0c;我刚准备出去打个羽毛球&#xff0c;北京的电话就来了。面试官各种抱歉&#xff0c;说开会拖延了。 1、自我介绍 说了很多遍了&#xff0c;很流畅捡重点介绍完。 2、问我数据结构算法好不好 挺好的&…

函数chown

一、chown 命令 下面以实例简单讲解下 chown 的使用方法。当前登录的账号是 sunbin 创建测试文件当前 test.txt 文件所有者是sunbin&#xff0c;所属组也是sunbin。 利用 chown 命令修改 test.txt 的所有者和所属组.可以看到&#xff0c;test.txt 的拥有者变成了 root&#…

不愧是Alibaba技术官,java数组实现单向链表

缓存雪崩 缓存雪崩指的是Redis当中的大量缓存在同一时间全部失效&#xff0c;而假如恰巧这一段时间同时又有大量请求被发起&#xff0c;那么就会造成请求直接访问到数据库&#xff0c;可能会把数据库冲垮。 缓存雪崩一般形容的是缓存中没有而数据库中有的数据&#xff0c;而因…

【线程】读写锁

一、概念 一把读写锁具备三种状态&#xff1a; 读模式下加锁状态(读锁&#xff09;写模式下加锁转态(写锁)不加锁状态2. 读写锁特性&#xff1a; 读写锁是写模式加锁时&#xff0c;解锁前&#xff0c;所有对该锁加锁的线程都会阻塞。读写锁是读模式加锁时&#xff0c;如果线程以…

不愧是阿里大佬,mysql存储过程写法案例

容器化时代来了 虚拟化技术已经走过了三个时代&#xff0c;没有容器化技术的演进就不会有 Docker 技术的诞生。 虚拟化技术演进 &#xff08;1&#xff09;物理机时代&#xff1a;多个应用程序可能会跑在一台机器上。 &#xff08;2&#xff09;虚拟机时代&#xff1a;一台物…