77范文网 - 专业文章范例文档资料分享平台

操作系统原理实验指导书(4)

来源:网络收集 时间:2020-06-03 下载这篇文档 手机版
说明:文章内容仅供预览,部分内容可能不全,需要完整文档或者需要复制内容,请下载word后使用。下载word有问题请添加微信号:或QQ: 处理(尽可能给您提供完整文档),感谢您的支持与谅解。点击这里给我发消息

echo “ b. User currently logged in”

echo “ c. Name of the working directory”

echo “ d. Contents of the working directory\\n” echo –n “Enter a,b,c or d:” read answer echo

case “$answer” in a)

date ;; b)

who ;; c)

pwd ;; d) ls ;; *)

Echo “There is no selection : $answer” ;; esac

6、修改上题,使用户可以连续选择直到想退出时才退出。 7、编程使用select结构生成一个菜单如下:

1)apple 3)blueberry 5)orange 7)STOP

2) banana 4)kiwi 6)watermelon

Choose your favorite fruit from these possibilities: 用户输入所选项,如 1 显示:

You chose apple as you favorite. That is choice number 1.

<参考程序> #!/bin/bash

ps3=“Chose your favorite fruit from these possibilities:”

select FRUIT in apple banana blueberry kiwi orange watermelon STOP do

if [ $FRUIT = STOP ] then echo “Thanks for playing!” break fi

echo “You chose $FRUIT as you favorite.” echo “That is choice number $REPLY.” echo done

<程序说明>

15

①select 结构的语法如下:

select varname[in arg?]

do commands done ②REPLY是键盘变量。

【思考题】

1、什么选项通知rm、cp和mv在删除或覆盖文件前得到用户的确认?

2、如何确认自己在主目录中?然后再主目录中创建一个名为Dannty的目录,再进入到Danny目录,并确认你的位置?

3、命令echo$PATH的输出是什么? 4、下列命令的运行结果是什么? who | grep $USER grep \\$HOME file1

【实验报告】

1.列出调试通过程序的清单,并加注释。 2.回答思考题。

3.总结上机调试过程中所遇到的问题和解决方法及感想。

【实验相关资料】

创建并使用脚本的步骤: ⑴创建shell命令文件。

⑵使用chmod命令使文件可执行。 ⑶通过输入脚本文件名执行文件。

在执行脚本时,shell读取脚本并按其指示执行。它逐行执行脚本,就像这些行是从键盘输入的一样。脚本中所有的实用程序都执行。

16

实验四 进程控制

【实验目的】

1、掌握进程的概念,明确进程和程序的区别。 2、认识和了解并发执行的实质。

3、分析进程争用资源的现象,学习解决进程互斥的方法。

【实验内容】

1、进程的创建(必做题)

编写一段程序,使用系统调用fork( )创建两个子进程,在系统中有一个父进程和两个子进程活动。让每个进程在屏幕上显示一个字符;父进程显示字符“a”,子进程分别显示字符“b” 和“c”。试观察记录屏幕上的显示结果,并分析原因。

<参考程序>

# include 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’); } }

2、 修改已编写的程序,将每个进程的输出由单个字符改为一句话,再观察程序执行时屏幕上出现的现象,并分析其原因。(必做题)

<参考程序>

# include main()

{ int p1, p2, i;

while((p1=fork())= = -1); if(p1= =0)

for(i=0;i<500;i++)

printf(“child%d\\n”,i); else

{ while((p2=fork())= =-1); If(p2= =0)

17

for(i=0;i<500;i++) printf(“son%d\\n”,i); else

for(i=0;i<500;i++)

printf(“daughter%d\\n”,i); } }

3、编写程序创建进程树如图1和图2所示,在每个进程中显示当前进程识别码和父进程识别码。(必做题)

父进程

b c d 图1 进程树

图2 进程树

子进程 b c a a d e 【思考题】

1、系统是怎样创建进程的?

2、当首次调用新创建进程时,其入口在哪里? 3、当前运行的程序(主进程)的父进程是什么?

【实验报告】

1、列出调试通过程序的清单,分析运行结果。

2、给出必要的程序设计思路和方法(或列出流程图)。 3、回答思考题。

4、总结上机调试过程中所遇到的问题和解决方法及感想。

【实验相关资料】

一、进程概念

1.进程

UNIX中,进程既是一个独立拥有资源的基本单位,又是一个独立调度的基本单位。一个进程实体由若干个区(段)组成,包括程序区、数据区、栈区、共享存储区等。每个区又分为若干页,每个进程配置有唯一的进程控制块PCB,用于控制和管理进程。PCB的数据结构如下: ⑴ 进程表项(Process Table Entry)。

包括一些最常用的核心数据,如: 进程标识符PID、用户标识符UID、进程状态、事件描述符、进程和U区在内存或外存的地址、软中断信号、计时域、进程的大小、偏置值nice、指向就绪队列中下一个PCB的指针P_Link、指向U区进程正文、数据及栈在内存区域的指针。 ⑵ U区(U Area)。

用于存放进程表项的一些扩充信息。每一个进程都有一个私用的U区,其中含有:进程表项指针、真正用户标识符u-ruid(read user ID)、有效用户标识符u-euid(effective user ID)、用户文件描述符表、计时器、内部I/O参数、限制字段、差错字段、返回值、信号处理数组。

18

由于UNIX系统采用段页式存储管理,为了把段的起始虚地址变换为段在系统中的物理地址,便于实现区的共享,所以还有: ⑶ 系统区表项。

以存放各个段在物理存储器中的位置等信息。系统把一个进程的虚地址空间划分为若干个连续的逻辑区,有正文区、数据区、栈区等。这些区是可被共享和保护的独立实体,多个进程可共享一个区。为了对区进行管理,核心中设置一个系统区表,各表项中记录了以下有关描述活动区的信息:区的类型和大小、区的状态、区在物理存储器中的位置、引用计数、指向文件索引结点的指针。 ⑷ 进程区表

系统为每个进程配置了一张进程区表。表中,每一项记录一个区的起始虚地址及指向系统区表中对应的区表项。核心通过查找进程区表和系统区表,便可将区的逻辑地址变换为物理地址。 2. 进程映像

UNIX系统中,进程是进程映像的执行过程,也就是正在执行的进程实体。它由三部分组成: ⑴ 用户级上、下文。主要成分是用户程序;

⑵ 寄存器上、下文。由CPU中的一些寄存器的内容组成,如PC,PSW,SP及通用寄存器等; ⑶ 系统级上、下文。包括OS为管理进程所用的信息,有静态和动态之分。

3.进程树

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

二、所涉及的中断调用

1、fork( )

创建一个新的子进程。其子进程会复制父进程的数据与堆栈空间,并继承父进程的用户代码、组代码、环境变量、已打开的文件代码、工作目录和资源限制。 系统调用格式:

int fork()

如果Fork成功则在父进程会返回新建立的子进程代码(PID),而在新建立的子进程中则返回0。如果fork失败则直接返回-1。 2、wait( )

等待子进程运行结束。如果子进程没有完成,父进程一直等待。wait( )将调用进程挂起,直至其子进程因暂停或终止而发来软中断信号为止。如果在wait( )前已有子进程暂停或终止,则调用进程做适当处理后便返回。 系统调用格式:

int wait(status) int *status;

其中,status是用户空间的地址。它的低8位反应子进程状态,为0表示子进程正常结束,非0则表示出现了各种各样的问题;高8位则带回了exit( )的返回值。exit( )返回值由系统给出。核心对wait( )作以下处理:

(1)首先查找调用进程是否有子进程,若无,则返回出错码;

(2)若找到一处于“僵死状态”的子进程,则将子进程的执行时间加到父进程的执行时间上,并释放子进程的进程表项;

(3)若未找到处于“僵死状态”的子进程,则调用进程便在可被中断的优先级上睡眠,等待其子进

19

百度搜索“77cn”或“免费范文网”即可找到本站免费阅读全部范文。收藏本站方便下次阅读,免费范文网,提供经典小说教育文库操作系统原理实验指导书(4)在线全文阅读。

操作系统原理实验指导书(4).doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印 下载失败或者文档不完整,请联系客服人员解决!
本文链接:https://www.77cn.com.cn/wenku/jiaoyu/1086232.html(转载请注明文章来源)
Copyright © 2008-2022 免费范文网 版权所有
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ: 邮箱:tiandhx2@hotmail.com
苏ICP备16052595号-18
× 注册会员免费下载(下载后可以自由复制和排版)
注册会员下载
全站内容免费自由复制
注册会员下载
全站内容免费自由复制
注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: