第二章 进程管理( 实验补充)课件.pptVIP

  • 1
  • 0
  • 约4.06千字
  • 约 22页
  • 2017-08-25 发布于广东
  • 举报
阜阳师范学院计算机与信息学院 补充实验内容 系统调用函数:fork( ) :创建一个新进程。 系统调用格式: pid=fork( ) 参数定义:int fork( ) fork( )返回值意义如下: 0:在子进程中,pid变量保存的fork( )返回值为0,表示当前进程是子进程。 0:在父进程中,pid变量保存的fork( )返回值为子进程的id值(进程唯一标识符)。 -1:创建失败。 如果fork( )调用成功,它向父进程返回子进程的PID,并向子进程返回0,即fork( )被调用了一次,但返回了两次。 此时OS在内存中建立一个新进程,所建的新进程是调用fork( )父进程(parent process)的副本,称为子进程(child process)。子进程继承了父进程的许多特性,并具有与父进程完全相同的用户级上下文(主要成分是用户程序)。父进程与子进程并发执行。 fork( )是对父进程的严格复制,而且子进程是从 fork( )的返回点开始运行的,而不是从程序的最初开始运行 程序中互斥的两个分支都被执行了,两行输出是来自两个进程,这两个进程是来来自同一个程序的两次执行。 #include?stdio.h main?() { ???int pid; ???while((pid=fork())==-1); ??????if?(pid?==?0) ????????printf(i?am?the?child?process,?my?process?id?is ?%d\n,getpid()); ??else ????????printf(i?am?the?parent?process,?my?process?id? is?%d\n,getpid()); } 结果是 [root@localhost?c]#?./a.out i?am?the?child?process,?my?process?id?is?4286 i?am?the?parent?process,?my?process?id?is?4285 如果exec( )调用成功,调用进程将被覆盖,然后从新程序的入口开始执行,这样就产生了一个新进程,新进程的进程标识符id 与调用进程相同。 exec( )没有建立一个与调用进程并发的子进程,而是用新进程取代了原来进程。所以exec( )调用成功后,没有任何数据返回,这与fork( )不同。 exec( )和fork( )联合使用 用fork( )建立子进程,然后在子进程中使用exec( ),这样就实现了父进程与一个与它完全不同子进程的并发执行。 一般,wait、exec联合使用的模型为: if (fork( )= =0) { ...........; execl(...); ...........; } 进程一旦调用了wait,就立即阻塞自己,由wait自动 分析是否当前进程的某个子进程已经退出,如果让它找 到了这样退出的子进程,wait就会收集这个子进程的信 息,并把它彻底销毁后返回;如果没有找到这样一个子 进程,wait就会一直阻塞在这里,直到有一个出现为止。 参数status用来保存被收集进程退出时的一些状态, 它是一个指向int类型的指针。但如果我们对这个子进程 是如何死掉的毫不在意,只想把这个子进程消灭掉, 我们就可以设定这个参数为NULL,就像下面这样: pid = wait(NULL); #include sys/types.h #include sys/wait.h main() { pid_t pc,pr; pc=fork(); if(pc0) /* 如果出错 */ printf(error ocurred!\n); else if(pc==0) { /* 如果是子进程 */ printf(This is child process with pid of %d\n,getpid()); sleep(10); /* 睡眠10秒钟 */ } else { /* 如果是父进程 */ pr=wait(NULL); /* 在这里等待 */ printf(I catched a child process with pid of %d\n),pr);

文档评论(0)

1亿VIP精品文档

相关文档