观察进程的并发性

观察进程的并发性

ID:30842151

大小:334.13 KB

页数:9页

时间:2019-01-04

观察进程的并发性_第1页
观察进程的并发性_第2页
观察进程的并发性_第3页
观察进程的并发性_第4页
观察进程的并发性_第5页
资源描述:

《观察进程的并发性》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、实验报告实验名称:日期:2014.5四观察进程的并发性五构造进程家族树六理解进程的独立空间班级:姓名:、实验目的1•观察进程的并发性1)、通过创建子进程,观察父子进程的并发执行过程,区别顺序执行和并发执行;明确进程和程序的区别;2)、加深对操作系统进程概念和进程并发特性的理解2.构造进程家族树通过创建若干个子进程,构造进程家族树,分析进程家族树的结构关系;学习相关系统调用(例如,getpid()和getppid()等)的使用方法。3.理解进程的独立空间理解进程是操作系统独立分配资源的单位,进程拥有白己相对独立的

2、程序空间。二、实验内容1、观察进程的并发性1、学习进程的基础知识;2、了解Linux系统中进程创建的基木原理;3、熟悉进程的创建、控制、执行和终止等系统调用函数;4、进程的创建编制一段程序,使用系统调用foi・k()创建两个子进程,在此程序运行时,系统中就有一个父进程和两个子进程在活动。让每一个进程在屏幕上显示一个字符:父进程显示字符a,两个子进程分别显示字符b和字符c。观察、记录并分析屏幕上进程调度和并发执行的情况:此时,在程序中使用系统调用nice()来改变各进程的优先级,观察、记录并分析屏幕上进程调度和并

3、发执行的情况2.构造进程家族树学习进程构造的相关知识,学习获取进程相关信息的系统调用函数。3.理解进程的独立空间预习进程创建和构造的相关知识,了解C语言程序编写的相关知识。三、项目要求及分析1.构造进程家族树进程的创建。编制一段程序,使用系统调用fork()创建三个子进程,在各个子进程中再使用系统调用forkO进一步创建子进程,如此重复,构造一棵具有图1形状的进程家族树。分别使用系统调用gctpid()和gctppid()获取当前进程和父进程的进程标识号并输出。PidllPidl21.理解进程的独立空间a.编写

4、一个程序,在其main()函数中定义一个变量shared,对其进行循环加/减操作,并输岀每次操作后的结果;b.使用系统调用fork()创建子进程,观察该变量的变化;C.修改程序把shared变量定义到main()函数之外,重复第(2)步操作,观察该变量的变化。具体实现1.流程图a.构造进程家族树

5、创建子进程Pidl

6、(结束)b.理解进程的独立空间开始调用父进程,执行shared输出shared值调用子进程,执行shared•输出shared值2.添加函数的代码a.构造进程家族树#include

7、#includevstdlib.h>#include#includevunistd•h>intmain(){intpidlfpidlafpidlb,pid2fpid3;//pidlpidl=fork();while(-l==pidl)pidl=fork();if(O==pidl){...…,.…printf(processltpid=%dppid=%d'tgetpid(),getppid());//pidlaIpidla=fork();while(-l==pidla)pidl

8、a=fork();if(0==pidla)printf(processlatpid=%dppid=%d",getpid(),getppid());elseelse//pidlbpidlb=fork();while(-l==pidlb)pidlb=fork();if(O==pidlb)printf(''processlbtpid=%dppid=%dM,getpid(),getppid());性}}else{//pid2pid2=fork();while(-l==pid2)pid2=fork()

9、;if(0==pid2)printf(process2tpid=%dppid=%d',getpid().getppid());Iseprintf(^process2tpid=%dppid=%dM,getpid(),getppid());Ise//pid3pid3=fork();while(-l==pid3)pid3=fork();if(0==pid3)printf(process3tpid=%dppid=%d*,getpid(),getppid());else//parentpri

10、ntf(nowis:parent*);}}return0;b.理解进程的独立空间intshared=O;intcount=0;intpid=fork();while(-l==pid)[pid=fork();if(O==pid){printf("child:);for(count=0;count<7;count++)printf("t%dM,shared++);)"else

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。