欢迎来到天天文库
浏览记录
ID:50472482
大小:1.47 MB
页数:49页
时间:2020-03-09
《计算机操作系统教程(第二版)教学课件 第7章几种常见操作系统典型功能的实现方法举例.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、第7章几种常见操作系统典型功能的实现方法举例7.1WindowsNT进程、线程的特点7.2UNIX进程管理7.3UNIX进程通信与同步机制7.4WindowsNT文件系统7.5UNIX文件系统索引结构介绍7.6Linux文件系统7.7UNIXNFS文件系统7.8WindowsNT存储管理的二级页表结构7.9Linux系统的内存管理技术7.10UNIX内存管理技术7.11UNIXI/O设备管理7.12LinuxI/O设备管理本章学习目标UNIX的进程管理及调度,包括进程同步机制介绍UNIX文件的物理结构Linux
2、操作系统文件名到文件分量的映射WindowsNT、Linux及UNIX内存管理技术Linux及UNIX设备管理7.1WindowsNT进程、线程的特点7.1.1WindowsNT进程、线程及对象之间的关系7.1.2进程管理程序7.1.3线程调度返回首页7.1.1WindowsNT进程、线程及对象之间的关系(1)线程是进程的一个组成部分。(2)进程多线程都在进程的地址空间活动。(3)资源是分给进程的,而不是分给线程的,并且系统还为分给进程的资源规定了配额。(4)调度的基本单位是线程。(5)线程在执行过程中需要同步
3、。返回本节7.1.2进程管理程序(1)客户进程用创建原语创建进程。(2)客户进程通过发送消息给相应的服务器进程。(3)服务器进程调用WindowsNT执行体的进程管理程序为之创建一个WindowsNT本机进程。(4)进程创建后,进程管理程序返回一个句柄给进程对象。(5)环境子系统取得该句柄,生成客户应用程序所期望的适合本环境的返回值。(6)环境子系统调用WindowsNT的进程管理程序为已创建的新进程创建一个线程。返回本节7.1.3线程调度在WindowsNT中,一个线程在它的生命期中要经历以下6种状态:(1)
4、就绪状态(2)备用状态(3)运行状态(4)等待状态(5)转换状态(6)终止状态(如图7.1所示)初始化就绪备用终止运行转换等待创建并初始化线程对象重新初始化放入就绪队列选择执行抢先资源成为可用的资源不可用抢先或时间片结束等待完成线程等待一个对象句柄执行完成描述表切换并开始执行(调度)图7.1线程的调度状态之间的转化图返回本节7.2UNIX进程管理7.2.1UNIX进程状态7.2.2UNIX进程描述7.2.3UNIX进程控制7.2.4UNIX进程调度返回首页7.2.1UNIX进程状态UNIX中共有9种进程状态:(
5、1)核心运行状态(2)用户运行状态(3)内存中就绪(4)内存中睡眠(5)就绪且换出(6)睡眠且换出(7)被抢占状态(8)创建状态(9)僵死状态(如图7.2所示)用户态执行返回到用户态返回系统调用、中断中断、中断返回僵死睡眠唤醒唤醒换出换出换入调度内存中睡眠睡眠且交换内存不足有足够内存创建剥夺核心态执行被剥夺状态终止内存中就绪fork123456789图7.2UNIX进程状态转化图返回本节7.2.2UNIX进程描述(1)一个进程是对一个程序的执行。(2)一个进程的存在意味着系统中存在着一个常驻内存的进程表项(pr
6、oc结构),它包含着相应进程的控制信息。(3)对每一个进程,有一个被称为U区的数据结构,这个结构中存放着该进程的私用控制信息。(4)一个进程可以生成或撤销其子进程。(5)一个进程是获得和释放各种系统资源的基本单位。返回本节7.2.3UNIX进程控制在UNIX系统中,除了0#进程之外,其他所有进程都是被另一个进程利用系统调用fork创建的。0#进程是一个特殊的系统进程,它是在系统引导时被创建的。系统初启时,0#进程创建了1#进程,此后0#进程就变成了交换进程,而1#进程变成了系统的始祖进程。UNIX系统利用for
7、k为每个终端创建一个子进程为用户服务,如等待用户登录、执行shell命令解释程序等。返回本节7.2.4UNIX进程调度由于UNIX系统是单纯的分时系统,所以没有设置作业调度。UNIX系统的进程调度采用的算法是,多级反馈队列轮转调度法。调度的算法如图7.3所示。核心先从最高优先级就绪队列中取出排在队列最前面的进程,当进程执行完一个时间片仍未完成则剥夺它的执行,将它放入到相应的队列中。然后,再从最高优先级就绪队列中取出下一个就绪进程投入运行。调度内存中有可运行的进程?选择内存中优先级最高、驻留时间最长的就绪或被剥夺
8、进程从就绪队列中移出切换到该进程的上下文恢复其执行CPU空闲NY图7.3UNIX进程调度算法返回本节7.3UNIX进程通信与同步机制UNIX系统V中的进程通信可分为4个部分:低级通信、管道通信、进程间通信和网络进程间通信。(1)低级通信主要用来传递进程间的控制信号。(2)管道通信用来在同一家族的进程间传递比特流。返回首页(3)进程间通信IPC是UNIX系统V的一个核心程序包,它负责完成
此文档下载收益归作者所有