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
{ 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
{ 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)在线全文阅读。
相关推荐: