当前位置导航:炫浪网>>网络学院>>操作系统>>Linux教程

linux多进程的总结(fork用法)


    简单理解为,一个进程表示的,就是一个可执行程序的一次执行过程中的一个状态。操作系统对进程的管理,典型的情况,是通过进程表完成的。进程表中的每一个表项,记录的是当前操作系统中一个进程的情况。对于单 CPU的情况而言,每一特定时刻只有一个进程占用 CPU,但是系统中可能同时存在多个活动的(等待执行或继续执行的)进程。

    fork()用于从已存进程中建立一个新进程,新进程为子进程,老进程为父进程.可以通过检查"fork()"地返回值知道哪个是子进程哪个是父进程。父进程得到的返回值是子进程的进程号,而子进程则返回0。

    基本模式是:

    #include
    #include
    #include
    #include
    #include
    #include
    main()
    {
    pid_t pid;
    int rv;
    pid=fork(); //创建进程
    switch(pid)
    {
    case -1: //返回-1的话,进程创建没成功
    perror("fork");
    exit(1);
    case 0:
    printf(" CHILD: This is the child process!\n");
    printf(" CHILD: My PID is %d\n", getpid()); //调用 getpid 得到自己的 PID
    printf(" CHILD: My parent's PID is %d\n", getppid()); //getppid() 得到父进程的 PID
    printf(" CHILD: Enter my exit status (make it small): ");
    scanf(" %d", &rv);
    printf(" CHILD: I'm outta here!\n");
    exit(rv);
    default:
    printf("PARENT: This is the parent process!\n");
    printf("PARENT: My PID is %d\n", getpid());
    printf("PARENT: My child's PID is %d\n", pid); //fork() 返回的default值意味着你正在父进程中,返回值是子进程的 PID 。这是得到子进程 PID 的唯一方法
    printf("PARENT: I'm now waiting for my child to exit()...\n");
    wait(&rv); //父进程必须等待子进程完成收拾子进程的残余后才能继续
    printf("PARENT: My child's exit status is: %d\n", WEXITSTATUS(rv)); 也就是父进程不能先于子进程消亡。
    printf("PARENT: I'm outta here!\n");
    }
    }
    //EXITSTATUS() 是一个宏,从 wait() 返回值中提取实际的返回值。
    // wait() 怎么知道在哪个进程上等待?我的意思是,由于父进程可以有多个子进程, wait() 实际等待地是哪一个?答案非常简单,它等待最先退出的那一个。你可以通过以子进程的 PID 为参数调用 waitpid() 指明是哪一个子进程。

    if (!fork())
    {
    printf("I'm the child!\n");
    exit(0);
    } else
    {
    printf("I'm the parent!\n");
    wait(NULL);
    }

    是多用户和多进程的操作系统,进程在操作系统中的创建,都会生成一个进程描述块,描述当前进程的所有信息,包括,数据段、代码段、堆栈段的地址,当前进程的环境变量,文件描述符等。

    fork函数过程:操作系统先创建一个进程描述块,然后把父进程的所有进程描述符的信息精确拷贝过来,和父进程一样(除了进程ID不一样外),代码段共享,数据段和堆栈段复制,所有的寄存器的值全部精确拷贝,文件描述符也许精确拷贝。

    fork的返回值,fork在父进程空间中返回子进程的PID,在子进程空间中返回0。 炫浪学院 Linux教程

相关内容
赞助商链接