信号#2

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折返性,重入性

保证可重入的函数

保证可以安全重入的函数#1

保证可以安全重入的函数#2

信号集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);
``




©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 使用场景:1、为了并发,中断处理其它事件,1、进程间通信1、中断中止(注意不是终止)当前正在执行的程序,转而执行其...
    奥斯特洛司机阅读 3,991评论 0 0
  • 信号是事件发生时对进程的通知机制,又称为软中断。当程序正常运行时,如果收到一个信号,那么程序的运行流程会被打断,等...
    loopppp阅读 3,101评论 0 0
  • 信号:信号的发送函数/信号集和信号屏蔽/介绍一个sigaction()/信号应用的相关函数:sleep(),usl...
    vera姐姐阅读 1,703评论 0 0
  • Linux 进程管理与程序开发 进程是Linux事务管理的基本单元,所有的进程均拥有自己独立的处理环境和系统资源,...
    JamesPeng阅读 7,192评论 1 14
  • 有朋友开古琴公益课,几次喊我有时间过去看看。下午去体验了一下。 去的时候已有六个人在,包括一位十岁的小姑娘,是跟她...
    玉见欢喜阅读 3,157评论 4 5