|
|
原创:lobbve223 出自: |
简单理解为,一个进程表示的,就是一个可执行程序的一次执行过程中的一个状态。操作系统对进程的管理,典型的情况,是通过进程表完成的。进程表中的每一个表项,记录的是当前操作系统中一个进程的情况。对于单 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); }
linux 是多用户和多进程的操作系统,进程在操作系统中的创建,都会生成一个进程描述块,描述当前进程的所有信息,包括,数据段、代码段、堆栈段的地址,当前进程的环境变量,文件描述符等。
fork函数过程:操作系统先创建一个进程描述块,然后把父进程的所有进程描述符的信息精确拷贝过来,和父进程一样(除了进程ID不一样外),代码段共享,数据段和堆栈段复制,所有的寄存器的值全部精确拷贝,文件描述符也许精确拷贝。
fork的返回值,fork在父进程空间中返回子进程的PID,在子进程空间中返回0。 | |
阅读(545) | 评论(0) | 转发(0) |