1

我得到了这段代码,并被告知运行它。经过一番研究,我认为这是fork炸弹,最终这里会出现分叉失败。

在我看来,根据[EAGAIN]x2 和 [ENOMEM]手册页,我认为这主要是由于与内存有关的原因。

但是,我有一个问题,如果

a) 可以使此代码在 LINUX 上没有分叉失败

b)从理论上讲,我可以对操作系统做些什么来使分叉失败停止,同时仍然fork()保留被保留的语义。

我目前对这个问题的回答可能是找到一种方法来回收 pid 以允许无限的内存,但我不确定我的答案。谁能帮我吗?

#include <unistd.h>
#include <stdio.h>
#define D 10000

double delay(unsigned long loops) 
{
    unsigned long i;
    double z = i, y;

    z = i;
    for (i = loops; i >= 1 ; i--) {
        y = ((double) loops)/((double) (loops - i + 1));
        z = (y*y + z)*i/((double) loops);
    }
    return z;
}

int main(int argc, char *argv[])
{
    int child;

    while (1) {
        if ((child=fork()) > 0)
            fprintf(stderr, "[%d] ", getpid());
        else if (child == -1)
            fprintf(stderr, "FAIL ");
        else delay(D); // Pick some large D to start with
    }
}
4

1 回答 1

2

大多数系统对可以创建的子进程的数量都有限制。这些是系统范围的限制或每个用户的限制。如果你在无限循环中分叉,你很可能会达到这样的限制。

在 Linux 上,您需要检查 ulimit 命令。

于 2019-03-10T14:28:17.680 回答