实验三进程控制

实验三进程控制

ID:38195652

大小:45.50 KB

页数:4页

时间:2019-05-25

实验三进程控制_第1页
实验三进程控制_第2页
实验三进程控制_第3页
实验三进程控制_第4页
资源描述:

《实验三进程控制》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、实验三进程控制【实验目的】1.掌握进程的概念,明确进程和程序的区别。2.认识和了解并发执行的实质。3.分析进程争用资源的现象,学习解决进程互斥的方法。【实验内容】1.进程的创建(必做题)编写一段程序,使用系统调用fork()创建两个子进程,在系统中有一个父进程和两个子进程活动。让每个进程在屏幕上显示一个字符;父进程显示字符“a”,子进程分别显示字符“b”和“c”。试观察记录屏幕上的显示结果,并分析原因。<参考程序>#includemain(){intp1,p2;while((p1=fork())

2、==-1);if(p1==0)putchar(‘b’);/*在子进程1中*/else/*在父进程中*/{while((p2=fork())==-1);if(p2==0)putchar(‘c’);/*在子进程2中*/else/*在父进程中*/putchar(‘a’);}}2.修改已编写的程序,将每个进程的输出由单个字符改为一句话,再观察程序执行时屏幕上出现的现象,并分析其原因。(必做题)<参考程序>#includemain(){intp1,p2,i;while((p1=fork())==-1);i

3、f(p1==0)for(i=0;i<500;i++)printf(“daughter%d”,i);else{while((p2=fork())==-1);If(p2==0)for(i=0;i<500;i++)printf(“son%d”,i);elsefor(i=0;i<500;i++)printf(“parents%d”,i);}}3.编写程序创建进程树如图1所示,在每个进程中显示当前进程识别码和父进程识别码。(必做题)a父进程子进程图1进程树bcd【思考题】1.系统是怎样创建进程的?2.当首次调用

4、新创建进程时,其入口在哪里?3.当前运行的程序(主进程)的父进程是什么?【实验报告】1.列出调试通过程序的清单,分析运行结果。2.给出必要的程序设计思路和方法(或列出流程图)。3.回答思考题。4.总结上机调试过程中所遇到的问题和解决方法及感想。【实验相关资料】一、进程概念1.进程UNIX中,进程既是一个独立拥有资源的基本单位,又是一个独立调度的基本单位。一个进程实体由若干个区(段)组成,包括程序区、数据区、栈区、共享存储区等。每个区又分为若干页,每个进程配置有唯一的进程控制块PCB,用于控制和管理进程。PCB的数

5、据结构如下:⑴进程表项(ProcessTableEntry)。包括一些最常用的核心数据,如:进程标识符PID、用户标识符UID、进程状态、事件描述符、进程和U区在内存或外存的地址、软中断信号、计时域、进程的大小、偏置值nice、指向就绪队列中下一个PCB的指针P_Link、指向U区进程正文、数据及栈在内存区域的指针。⑵U区(UArea)。用于存放进程表项的一些扩充信息。每一个进程都有一个私用的U区,其中含有:进程表项指针、真正用户标识符u-ruid(readuserID)、有效用户标识符u-euid(effect

6、iveuserID)、用户文件描述符表、计时器、内部I/O参数、限制字段、差错字段、返回值、信号处理数组。由于UNIX系统采用段页式存储管理,为了把段的起始虚地址变换为段在系统中的物理地址,便于实现区的共享,所以还有:⑶系统区表项。以存放各个段在物理存储器中的位置等信息。系统把一个进程的虚地址空间划分为若干个连续的逻辑区,有正文区、数据区、栈区等。这些区是可被共享和保护的独立实体,多个进程可共享一个区。为了对区进行管理,核心中设置一个系统区表,各表项中记录了以下有关描述活动区的信息:区的类型和大小、区的状态、区在

7、物理存储器中的位置、引用计数、指向文件索引结点的指针。⑷进程区表系统为每个进程配置了一张进程区表。表中,每一项记录一个区的起始虚地址及指向系统区表中对应的区表项。核心通过查找进程区表和系统区表,便可将区的逻辑地址变换为物理地址。2.进程映像UNIX系统中,进程是进程映像的执行过程,也就是正在执行的进程实体。它由三部分组成:⑴用户级上、下文。主要成分是用户程序;⑵寄存器上、下文。由CPU中的一些寄存器的内容组成,如PC,PSW,SP及通用寄存器等;⑶系统级上、下文。包括OS为管理进程所用的信息,有静态和动态之分。3

8、.进程树在UNIX系统中,只有0进程是在系统引导时被创建的,在系统初启时由0进程创建1进程,以后0进程变成对换进程,1进程成为系统中的始祖进程。UNIX利用fork()为每个终端创建一个子进程为用户服务,如等待用户登录、执行SHELL命令解释程序等,每个终端进程又可利用fork()来创建其子进程,从而形成一棵进程树。可以说,系统中除0进程外的所有进程都是用fork()创建

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

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

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