fork在shell中如何工作

fork在shell中如何工作

#include
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
main()
{
    printf("my pid is %d",getpid());
    fork();
    fork();
    fork();
    printf("my pid is %d",getpid());
}
//这块代码很奇怪,只输出4条,按理说子进程也能fork出来子进程啊
#include
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)。最后需要知道如何让父进程等待子进程结束。

你可能感兴趣的:(fork在shell中如何工作)