Sending a Signal发送一个信号
#include <sys/types.h>
#include <signal.h>
int kill(pid_t pid, int signo);
如果pid>0,那么经发送给pid对应的那个进程。
如果pid=0,那么将发送给进程组里的每个进程。
如果pid=-1,那么将发送给除了自己和init之外的每个进程。
如果pid<-1,那么就发送给进程组-pid。
成功调用返回0,失败返回-1,并设置errno。
权限
拥有CAP_KILL权限的进程可以发送一个信号Signal给任意进程。
如果没有这个能力,那么发送进程的effective或real user ID必须与接收信号的进程相同。
简单来说就是一个用户只能给自己拥有的进程发送信号。
如果signal=0,那么调用将不发送任何信号,但他仍然会进行错误检查,这通常被用来进程检查是否有权限发送信号给被提供的进程。
Examples
int ret;
ret = kill (1722, SIGHUP);
if (ret)
perror ("kill");
int ret;
ret = kill (1722, 0);
if (ret)
; /* we lack permission */
else
; /* we have permission */
给自己发送信号
#include <signal.h>
int raise(int signo);
raise(signo) == kill(getpid(), signo)
成功返回0,失败返回非0,但不设置errno。
发送一个信号给整个进程组
#include <signal.h>
int killpg(int pgrp, int signo);
killpg(pgrp,signal) == kill(-pgrp, signo)
成功返回0,失败返回-1,并设置errno。
Reentrancy折返性,重入性
保证可重入的函数
信号集Signal Sets
#include <signal.h>
int sigemptyset (sigset_t *set);
int sigfillset (sigset_t *set);
int sigaddset (sigset_t *set, int signo);
int sigdelset (sigset_t *set, int signo);
int sigismember (const sigset_t *set, int signo);
sigemptyset()初始化set给出的信号集,并将其标记为空(所有信号被排除在外)。
sigfillset()初始化set给出的信号集,并将其标记为满(所有set中的信号)。
这两个函数都返回0。你应该在用信号集之前调用其中的一个。
sigaddset()往set中加入一个signo。
sigdelset()往set中移除一个signo。
这两个函数都是成功返回0,失败函数-1,并设置errno。
sigismember()如果signo是这个signo set中的则返回0,不然返回-1,并设置errno。
更多的信号集函数
#define _GNU_SOURCE
#define <signal.h>
int sigisemptyset (sigset_t *set);
int sigorset (sigset_t *dest, sigset_t *left, sigset_t *right);
int sigandset (sigset_t *dest, sigset_t *left, sigset_t *right);
如果set给出的信号集为空,则sigisemptyset()返回1,否则为0。
sigorset()将信号集left和right的联合(二进制或)放置在dest中。
sigandset()将信号集的left和right的交集(二进制和)放置在dest中
这两个函数成功返回0。失败返回-1,并设置errno。
Blcoking Signals阻塞信号
#include <signal.h>
int sigprocmask (int how, const sigset_t *set, sigset_t *oldset);
how的参数如下:
- SIG_SETMASK
调用进程的信号掩码被更改为设置。 - SIG_BLOCK
集合中的信号被添加到调用进程的信号掩码中。换句话说,信号掩码被更改为当前掩码和设置的合并(二进制OR)。 - SIG_UNBLOCK
集合中的信号从调用进程的信号掩码中删除。换句话说,信号被改变为当前掩码的交集(二进制和),和否定(二进制非)的set。 打开一个没有被阻塞的信号是非法的。
如果oldset不是NULL,则函数将前面的信号集放在oldset中。
如果set为NULL,则函数将忽略how,也不会更改信号掩码,但它确实将信号掩码放置在旧集中。换句话说,将空值作为set传递是检索当前信号掩码的一种方式。
不允许阻塞SIGKILL或SIGSTOP。Sigpromask()静默地忽略试图将其中一个信号添加到信号掩码中的行为。
检索待测信号
#include <signal.h>
int sigpending (sigset_t *set);
成功地调用sigpending()时,将挂起的信号集中到set中,并返回0。失败时,调用返回−1并将errno设置为EFAULT,这意味着SET是无效指针。
等待信号集
#include <signal.h>
int sigsuspend(const sigset_t *set);
``