函数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);		
	}
}
输出结果:
发送端:
接收端:
————————————————
                            版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
                        
原文链接:https://blog.csdn.net/isunbin/article/details/83997138
 
                    
                     
                    
                 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号