进程的创建与管理详解.doc

  1. 1、本文档共64页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
目 录  TOC \o 1-1 \u 实验1进程管理  PAGEREF _Toc409082116 \h 2 实验2进程间通信 15 实验3存储管理 21 实验4文件系统设计 31  实验目的: (1)加深对进程概念的理解,明确进程和程序的区别。 (2)进一步认识并发执行的实质。 (3)分析进程争用资源的现象,学习解决进程互斥的方法。 (4)了解Linux系统中进程通信的基本原理。实验内容: 1.进程的创建 编写一段程序,使用系统调用fork()创建两个子进程。当此程序运行时,在系统中有一个父进程和两个子进程活动。让每一个进程在屏幕上显示一个字符:父进程显示字符“a”;子进程分别显示字符“b”和“c”.试观察记录屏幕上的显示结果,并分析原因。 2.进程的控制 修改已编写的程序,将每个进程输出一个字符改为每个进程输出一句话,再观察程序执行时屏幕上出现的现象,并分析原因。 如果在程序中使用系统调用lockf()来给每一个进程加锁,可以实现进程之间的互斥,观察并分析出现的现象。 3.进程的软中断通信 (1)编制一段程序,使其实现进程的软中断通信。 要求:使用系统调用fork()创建两个子进程,再用系统调用signal()让父进程捕捉键盘上来的中断信号;当捕捉到信号后,父进程用系统调用kill()向两个子进程发出信号,子进程捕捉到信号后分别输出子下列信息后终止: Child process 1 is killed by parent! Child process 2 is killed by parent! 父进程等待两个子进程终止后,输出如下的信息后终止: Parent process is killed! (2)在上面的程序中增加语句signal(SIGINT,SIG_IGN)和signal(SIGQUIT,SIG_IGN),观察执行结果,并分析原因。 4.进程的管道通信 编制一段程序,实现进程的管道通信。 使用系统调用pipe()建立一条管道线;两个子进程P1和P2分别向管道各写一句话: Child 1 is sending a message! Child 2 is sending a message! 而父进程则从管道中读出来自两个子进程的消息,显示在屏幕上。 要求父进程先接收子进程P1发来的消息,然后再接收子进程P2发来的消息。 实验原理: 进程的创建程序如下: #includestdio.h main() { int p1,p2; while((p1=fork())==-1); if(p1==0) putchar(b); else { while((p2=fork())==-1); if(p2==0) putchar(c); else putchar(a); } } 1进程的控制程序1: #includestdio.h main() { int p1,p2,i; while((p1=fork())==-1); if(p1==0) for(i=0;i50;i++) printf(child %d\n,i); else { while((p2=fork())==-1); if(p2==0) for(i=0;i50;i++) printf(son %d\n,i); else for(i=0;i50;i++) printf(daughter %d\n,i); } } 2.2 进程的控制程序2: #includestdio.h #includeunistd.h main() { int p1,p2,i; while((p1=fork())==-1); if(p1==0) { lockf(1,1,0); for(i=0;i50;i++) printf(child %d\n,i); lockf(1,0,0); } else { while((p2=fork())==-1); if(p2==0) { lockf(1,1,0); for(i=0;i50;i++) printf(son %d\n,i); lockf(1,0,0); } else { lockf(1,1,0); for(i=0;i50;i++); printf(dau

文档评论(0)

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

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

1亿VIP精品文档

相关文档