killpg() 函数原型如下:
[C++] 纯文本查看 复制代码 #include <signal.h>
int killpg(int pgrp, int sig);
killpg() 可以将 sig 信号发送到第 1 个参数 pgrp 指定的进程组。各种信号信息可以通过 man 7 signal 命令查看。
如果 pgrp 为 0,那么 killpg() 发送信号到调用进程的进程组。
调用进程发送信号需要考虑权限问题,特权进程(CAP_KILL)几乎可以给任何进程组发送信号,如果不是特权进程组,那么发送进程的真实用户 ID 或 有效的用户 ID 必须等于目标进程的真实用户 ID 或 有效的用户 ID 。对于 SIGCONT 信号,如果发送和接收进程都属于同一个会话,那么不会产生权限问题。
测试代码:
[C++] 纯文本查看 复制代码 #include <stdio.h>
#include <stdlib.h>
#include <signal.h>
int main()
{
printf ("kill myself\n");
killpg (0, 9);
printf ("Can not print\n");
return 0;
}
运行输出:[beyes@beyes signal]$ ./killpg
kill myself
已杀死 上面程序运行时,它的 PID 和进程组ID(PGID) 是一样的,也就是它所创建的进程组里只有它自己,同时它也是进程组的组长。因此,程序中的行为也等效于自己杀死自己。
如果上面的例子看起来有点特殊,那么可以做其它的实验。先打开两个终端窗口,在第 1 个终端窗口里运行下面命令,查看当前的 PGID :[beyes@beyes ~]$ ps -p $$ -o 'pid pgid sid'
PID PGID SID
3082 3082 3082 从上面可以看到,该 shell 的组ID 为 3082,实际上它就是等于该 shell 的进程ID。
将上面程序中的 killpg(0, 9) 改成 killpg(3082, 9) ,然后切换为 root 运行,那么会发现该终端窗口被关闭了。 |