实验一进程的管理.doc

  1. 1、本文档共4页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实验一进程的管理

实验一 进程的?? 实验目的: (1) 熟悉Linux工作环境和GCC工具 (2) 加深对进程概念的理解,明确进程和程序的区别 (3) 进一步认识并发进程的实质和特征 实验仪器及材料: 微型计算机、红帽子Linux系统 实验内容: 任务1:进程创建 编写一段程序,让父进程产生两个子进程,父进程显示字符“a”、两个子进程,分别显示字符“b”、“c”。 #include stdio.h main(){ int? p1, p2 while ((p1=fork())==-1); /*父进程创建第一个进程,直到成功*/ if (p1==0)? /*0返回给子进程1*/ ??? putchar(‘b’); /*P1的处理过程*/ else {? /*正数返回给父进程(子进程号)*/ ? while ((p2=fork())==-1);? /*父进程创建第二个进程,直到成功*/ ??? if (p2==0)? /* 0返回给子进程2*/ putchar(‘c’);? /*P2的处理过程*/ else? putchar(‘a’); /*P2创建完成后,父进程的处理过程*/ } } 运行程序,观察运行结果,并分析。 任务2:将上述的输出字符改为输出较长的字符串,观察进程并发执行,分析执行结果。 #include stdio.h main(){ int? p1, p2 while ((p1=fork())==-1); /*父进程创建第一个进程,直到成功*/ if (p1==0) for (i=0;i500;i++) ?? printf(“child1%d\n”,i) else { ? while ((p2=fork())==-1); /*父进程创建第二个进程,直到成功*/ if (p2==0) for (i=0;i500;i++) ??????? printf(“child2%d\n”,i) else /*P2创建完成后,父进程的处理过程*/ for (i=0;i500;i++) ??????? printf(“parents%d\n”,i); } } 涉及到的系统调用: fork( ) ,创建一个新进程。 系统调用格式: pid=fork(? ) fork(? )返回值意义如下: 0:在子进程中,pid变量保存的fork(? )返回值为0,表示当前进程是子进程。 0:在父进程中,pid变量保存的fork(? )返回值为子进程的id值(进程唯一标识符)。 -1:创建失败。 如果fork( )调用成功,它向父进程返回子进程的PID,并向子进程返回0,即fork( )被调用了一次,但返回了两次。此时OS在内存中建立一个新进程,所建的新进程是其父进程(parent process)的副本,称为子进程(child process)。子进程继承了父进程的许多特性,并具有与父进程完全相同的用户级上下文。父进程与子进程并发执行。 思考:当新创建进程开始执行时,其入口在哪里?

文档评论(0)

qwd513620855 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档