fork在shell中如何工作
#include<stdio.h>
main()
{
int ret_from_fork,mypid;
mypid = getpid();
printf("Before: my pid is %d\n",mypid);
ret_from_fork=fork();
sleep(1);
printf("After:my pid is %d ,fork() said %d\n",
getpid(),ret_from_fork);
}
输出:
Before: my pid is 24702
After:my pid is 24702 ,fork() said 24703
After:my pid is 24703 ,fork() said 0
这里看到三行输出,一行Before:信息和两行After:信息。进程24702现是打印Before:消息,然后它又打印After消息----一切正常,另一个After:信息由进程24703打印的。注意进程24703没有打印Before:信息。
内核通过复制进程 24702来创建进程 24703,它将 24702的代码和当前运行到的位置都复制给 4171 。其中当前运行的位置是由随着代码向下移动的箭头表示的。新的进程 24703从fork 返回的地方开始运行,而不是从开头开始运行。因为 24703是从中间开始运行的,也就不打印 Before: 信息了 。
#include<stdio.h>
main()
{
printf("my pid is %d",getpid());
fork();
fork();
fork();
printf("my pid is %d",getpid());
}
//这块代码很奇怪,只输出4条,按理说子进程也能fork出来子进程啊
#include<stdio.h>
main()
{
int fork_rv;
printf("Before: mypid is %d\n",getpid());
fork_rv = fork();
if(fork_rv == -1)
perror("fork");
else if (fork_rv==0)
printf("I am the child. mypid =%d",getpid());
else
printf("I am the parent. mypid =%d",getpid());
}
系统调用fork正是解决shell只能运行一条命令这个问题所需要的。使用fork不但能够创建新的进程,而且能够分辨原来的进程和新创建的进程。新的进程能调用execvp来执行任何用户指明的程序。这里明确建立一个shell所需三项技术中的两项。知道了如何建立进程(fork)和如何运行一个程序(execvp)。最后需要知道如何让父进程等待子进程结束。