我们都知道,父进程fork()之后返回值为子进程的pid号,而子进程fork()之后的返回值为0。那么,现在就有一个问题了,子进程fork()的返回值是怎么来的?如果子进程又执行了一遍fork()函数,那么,按着完全复制的效果,父进程应该还会再fork()一次才对啊。其实,在fork()函数执行中,返回值是存放在寄存器eax中的,在子进程中fork()的结尾处,把eax置为0就可以啦。这样,就造成一种子进程也完整运行一次fork()的“假象”