Chinaunix首页 | 论坛 | 博客
  • 博客访问: 103184936
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类: LINUX

2008-05-23 23:19:07

原创: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。
阅读(542) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~