观察进程的并发性.doc

观察进程的并发性.doc

ID:51389553

大小:410.50 KB

页数:8页

时间:2020-03-23

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

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

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

2、;2、了解Linux系统中进程创建的基本原理;3、熟悉进程的创建、控制、执行和终止等系统调用函数;4、进程的创建编制一段程序,使用系统调用fork()创建两个子进程,在此程序运行时,系统中就有一个父进程和两个子进程在活动。让每一个进程在屏幕上显示一个字符:父进程显示字符a,两个子进程分别显示字符b和字符c。观察、记录并分析屏幕上进程调度和并发执行的情况:此时,在程序中使用系统调用nice()来改变各进程的优先级,观察、记录并分析屏幕上进程调度和并发执行的情况2.构造进程家族树学习进程构造的相关知识,学习获取进程相关信息的系统调用函数。3.理解进程的独立空间预习进程创建和构造的

3、相关知识,了解0语言程序编写的相关知识。三、项目要求及分析1.构造进程家族树进程的创建。编制一段程序,使用系统调用fork()创建三个子进程,在各个子进程中再使用系统调用fork()进一步创建子进程,如此重复,构造一棵具有图1形状的进程家族树。分别使用系统调用getpid()和getppid()获取当前进程和父进程的进程标识号并输出。1.理解进程的独立空间a.编写一个程序,在其main()函数中定义一个变量shared,对其进行循环加/减操作,并输出每次操作后的结果;b.使用系统调用fork()创建子进程,观察该变量的变化;C.修改程序把shared变量定义到main()函数

4、之外,重复第(2)步操作,观察该变量的变化。四、具体实现1.流程图a.构造进程家族树(结束)b.理解进程的独立空间/2-添加函数的代码a>构造进程家族树#includecstdio.h>#include#includevsys/types.h>#includeintmain(){intpidltpidlafpidlbtpid2fpid3;//pidlpidl=fork();while(-l==pidl)pidl=fork();if(O==pidl){printf(processltpid=%dppid=%dMfgetpid()

5、fgetppid());//pidlaIpidla=fork();while(-l==pidla)pidla=fork();if(O==pidla)printf('processlatpid=%dppid=%d",getpid(),getppid());elseelse//pidlbpidlb=fork();while(-l==pidlb)pidlb=fork();if(O==pidlb)printf("processlbtpid=%dppid=%d".getpid(),getppid());}}else{//Pid2pid2=fork();while(-

6、l==pid2)pid2=fork();if(0==pid2)printf("process2tpid=%dppid=%d',getpid().getppid());Iseprintf(process2tpid=%dppid=%d,,getpid(),getppid());Ise//pid3pid3=fork();while(-l==pid3)pid3=fork();if(0==pid3)printf("process3tpid=%dppid=%d",getpid(),getppid());else//parentprintf(nowis:par

7、ent");}}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(Mt%dM,shared++);)else{printf("parent:");for(count=0;count<7;count++)printf("t%d",shared++

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

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

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