发送信号的方式主要有下面两种方式:
#include <signal.h>
1、kill(pid_t pid,int sig);
2、sigqueue(pid_t pid,int sig,const union sigval value);
下面详细说明这两种方法的区别:
kill()
- pid为目标进程的进程ID,sig为要向目标发送的信号
- 如果pid>0,那么kill()会向进程id为pid的进程发送信号
- 如果pid=0,那么会发送信号给调用进程同组的所有进程信号,包括调用进程自己
- 如果pid=-1,那么会发送信号给该pid绝对值的进程组内所有的下属进程发送信号
- 如果pid<-1,那么信号的发送范围是:调用进程有权将信号发送到每个目标进程,出去init进程和调用进程自身
sigqueue()
- sigqueue()与kill不同的地方是多了第三个参数,可以向目标发送一个int类型的数据,与kill()不同的是sigqueue不能将pid设置为负数
下面是发送信号端的代码:
#define _GNU_SOURCE
#include <signal.h>
#include <string.h>
#include <setjmp.h>
#include "signal_functions.h"
#include "tlpi_hdr.h"
int main(int argc,char* argv[])
{
int sig,numSigs,j,sigData;
union sigval sv;
if(argc<4||strcmp(argv[1],"--help") ==0)
usageErr("%s pid sig-num data [num-sigs]\n", argv[0]);
printf("%s: PID is %ld, UID is %ld\n", argv[0],
(long) getpid(), (long) getuid());
sig = getInt(argv[2],0,"sig-num");
sigData=getInt(argv[3],GN_ANY_BASE,"data");
numSigs = (argc>4)?getInt(argv[4],GN_GT_0,"num-s"):1;
for(j=0;j<numSigs;j++)
{
sleep(1);
sv.sival_int = sigData+j;
if(sigqueue(getLong(argv[1],0,"pid"),sig,sv)== -1)
errExit("sigqueue %d",j);
}
exit(EXIT_SUCCESS);
}
下面是接收信号端的代码:
#define _GNU_SOURCE
#include <signal.h>
#include <stdio.h>
#include <stdlib.h>
static void
handler(int signum,siginfo_t *sv,void *myact)
{
printf("receive signal %d\n", signum);
printf("signal value is %d\n",sv->si_value.sival_int);
}
int main(int argc,char* argv[])
{
struct sigaction sa;
sa.sa_handler=handler;
sigemptyset(&sa.sa_mask);
sa.sa_flags = SA_SIGINFO; /* Handler uses alternate stack */
if (sigaction(SIGINT, &sa, NULL) == -1)
{
perror("sigaction\n");
exit(1);
}
while(1)
{
sleep(1);
}
exit(EXIT_SUCCESS);
}
欢迎关注问我团队公众号: