我知道我可以使用技巧if (fork()) exit(0);
来更改当前进程的pid。因此,以下程序的pid将很快发生变化。如何杀死这样的进程?有没有比执行大量killall procname
更好的方法,直到能够在分叉之前运行kill()
?我知道这不是一个"进程",而是许多进程,每个进程运行几微秒。
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>
int main()
{
pid_t self = getpid();
while (1)
{
if (fork()) exit(0);
if (self + 10000 < getpid()) break; // Just to kill it after some time
usleep(1000);
}
return 0;
}
此外,我发现列出该过程的唯一方法是执行几次ps -A | grep procname
,直到显示一些输出。为什么不始终列出该过程?
这样的过程被系统管理员称为"彗星"。
进程组 ID (PGID) 在分叉时不会更改,因此您可以通过向进程组发送信号来终止(或SIGSTOP
它)(您将否定的 PGID 而不是 PID 传递给 kill
)。
我能明白为什么你看不到它的唯一原因是分叉子项尚未创建,但父项在死亡中已经取得了足够的进展,以至于不再列出。
不幸的是,我认为不可能在没有猜测的情况下杀死这种过程。要做到这一点,需要提前知道下一个pid。您可以猜测下一个 pid,但不确定没有其他 pid 被分配。