我们知道PC指针保存的是下一条将要执行的指令地址
函数调用时PC指针入栈,函数返回时就会恢复到函数的下一条指令。
下面的函数运行到fork()时,PC保存的是printf那里的地址,由于fork()基本复制了当前进程,那么复制后的进程的PC值同样是printf那里
现在他们在系统中是独立的了,当操作系统调度到主进程时,根据PC指针,执行printf函数;调度到子进程时,根据PC指针,也执行自己的printf函数;
所以调用一次fork函数打印出了两条不同的结果,其实是在不同的进程中打印的。fork返回的还是一个值。
如果用一个for(i=0; i < 5; i++)循环来调用fork,可不是打印10条语句那么简单,根据PC指针的位置和当前复制的信息,深入到这个循环去看看,有助于理解多进程和fork函数。
参考资料:http://os.chinaunix.net/a2012/0203/1306/000001306508.shtml