操作系统原理PPT.ppt
《操作系统原理PPT.ppt》由会员分享,可在线阅读,更多相关《操作系统原理PPT.ppt(232页珍藏版)》请在三一办公上搜索。
1、操 作 系 统 原 理,武汉大学计算机多媒体课程,1、操作系统原理教材2、操作系统原理实验大纲指导教材3、操作系统课件多媒体教案,课程使用的媒体,一、操作系统的有关概念二、进程管理三、存储器管理,计算机发展简史操作系统的发展过程,计算机发展简史,按硬件发展划分为四代。,对计算规律的模拟,存储程序式计算机,存储程序式计算机模型,存储程序式计算机模型的基本方案是,如要使计算机能够自动地计算,必须有一个存储器用来存储程序和数据;同时要有一个运算器,用以执行指定的操作;有一个控制器,以便实现自动操作;另外,辅以输入/输出部件,以便输入原始数据和输出计算结果。于是形成了现代计算机的基本组成形式。如图1.
2、1所示。,图1.1 存储程序计算机的组成,操作系统的发展过程,按技术发展与分支划分类别,操作系统的类型,早期批处理执行系统多道成批系统 分时、实时系统、个人机系统 多处理机、分布式系统,无操作系统的计算机,从第一代计算机诞生到20世纪50年代中期还未出现操作系统,这时的计算机采用人工操作方式。其过程是:,图1.2 手工操作计算机,单道批处理系统与多道批处理系统及执行系统,所谓批处理系统是指加载在计算机上的一个系统软件,在它的控制下,计算机能够自动地成批地处理一个或多个用户的作业。首先出现的是联机批处理系统。如下图所示。,脱离主机控制的输入/输出批处理系统,在外设处理数据时,主机处理“忙等”状态
3、,这样高速的主机与慢速的外设矛盾就显现出来。为了克服与缓解主机与外设的矛盾。我们引入脱机批处理系统,即脱离主机控制的输入/输出批处理系统。如图1.4所示。,图1.4 脱机批处理系统,在单道批处理系统中,内存中仅有一道作业,中断和通道技术出现以后,虽然可以实现输入/输出设备与中央处理机并行操作,但由于属于同一道作业的可并发执行的进程不多,大多数进程是有同步关系的,这使系统中仍有较多的空闲资源,致使系统的性能较差。为了进一步提高资源的利用率和系统对作业的吞吐量,在60年代中期,引入了多道程序设计技术,由此而形成了多道批处理系统。单道程序与多道程序的执行过程如图1.5和图1.6所示。,在操作系统中引
4、入多道程序设计技术以后,会使系统具有以下特征。,(1)多道性(2)无序性(3)宏观上并行、微观上串行(4)调度性,分时系统,分时技术是把处理机的时间分成很短的时间片,这些时间片轮流地分配给各个联机的各作业使用。如果某作业在分配给它的时间片用完时仍未完成,则该作业就暂时中断,等待下一轮运行,并把处理机的控制权让给另一个作业使用。这样在一个相对较短的时间间隔内,每个用户作业都能得到快速响应,以实现人机交互。,分时系统与多道批处理系统相比,具有完全不同的特征,由上所述可以归纳成以下几点:,(1)多路性(2)独立性(3)及时性(4)交互性,什么是操作系统操作系统的性质,操作系统是控制和管理计算机系统内
5、各种硬件和软件资源、有效地组织多道程序运行的系统软件(或程序集合),是用户与计算机之间的接口。,以下软件哪些是操作系统?UNIX Word DOS VB Office FoxPro Windows 98 Windows NT Linux PowerPoint,以下软件是操作系统:UNIX DOS Linux Windows 98 Windows NT,设置OS的目的,扩充机器功能,方便用户使用。提高系统效率。,操作系统的共同性质,1、从功能上看,具有五大功能-存储器管理、处理机管理、设备管理、文件管理、用户接口,2、从层次上看,是裸机之上的第一层软件,为其他软件的建立和运行提供基础。,1。4节
6、,3、从服务上看,提供众多基础服务,方便用户使用,构成软件平台。,4、从内部特征上看,-支持并发性-实现资源共享-完成进程的异步前进,以多道成批系统为例,并发共享不确定性,1.3 OS的服务功能,程序执行I/O操作文件系统管理出错检测资源分配统计保护,一 系统调用,是应用程序与OS的接口进程或作业控制:实现进程或作业的所有活动文件管理和设备管理信息维护:用户与系统交互信息,二 系统程序,文件管理状态信息文件修改程序设计语言支持程序装入与执行工具性软件命令解释程序的实现方法,1.5操作系统逻辑结构设计,分层实现的软件设计方法,1.5操作系统逻辑结构设计,单块结构层次结构:分层实现的软件设计方法.
7、虚拟机客户/服务器模型:再用户进程方式下实现系统的多数功能;核心只负责客户与服务器的通信;适用于分布式系统;注意对关键基础服务的处理.,1。8 UNIX系统的特点和结构,UNIX的主要特点UNIX系统结构UNIX系统核心结构,一、操作系统的有关概念二、进程管理三、存储器管理,进程概念,程序的顺序执行与并发执行,程序的顺序执行,概念一个程序由若干个程序段组成,而这些程序段的执行必须是顺序的,这种程序执行的方式就称为程序的顺序执行。例如:,程序顺序执行的特点,1 顺序性处理机严格按照程序所规定的顺序执行,即每个操作必须在下一个操作开始之前结束。2 封闭性程序一旦开始执行,其计算结果不受外界的影响,
8、当程序的初始条件给定之后,其后的状态只能由程序本身确定,即只有本程序才能改变它。,程序顺序执行的特点(续),3 可再现性程序执行的结果与初始条件有关,而与执行时间无关。即只要程序的初始条件相同,它的执行结果是相同的,不论它在什么时间执行,也不管计算机的运行速度。O=f(I),f是与时间无关的函数,程序的并发执行,例:在系统中有n个作业,每个作业都有三个处理步骤,输入数据、处理、输出,即Ii,Ci,Pi(i=1,2,3,.,n)。这些作业系统中执行时是对时间的偏序,有些操作必须在其它操作之前执行,这是有序的,但有些操作是可以同时执行的。,程序的并发执行,例如:P1与I2,C1与I2,I3与P1是
9、可以同时执行的。,I1、C1、P1的执行必须严格按照I1,C1,P1的顺序。,I1、I2、I3、I4轮流使用同一输入设备。,时间,资源,程序的并发执行定义,若干个程序段同时在系统中运行,这些程序的执行在时间上是重迭的,一个程序段的执行尚未结束,另一个程序段的执行已经开始,即使这种重迭是很小的,也称这几个程序段是并发执行的。,程序的并发执行分析,优点:程序的并发执行提高了资源的利用率。注意有限制规则:同一作业的处理步骤的执行必须严格按照规定的顺序;同一独占资源上的不同作业的处理步骤不能同时执行。,程序的顺序执行与并发执行,假设有一个程序由S0Sn+1个语句,先顺序执行S0,然后并发执行 S1Sn
10、语句,最后顺序执行Sn+1。,程序并发执行的特点,一、失去了程序的封闭性,如果程序执行的结果是一个与时间无关的函数,即具有封闭性。,程序B打印0,程序B打印1,程序并发执行的特点,二、程序与计算不再一一对应在程序顺序执行时,一个程序总是对应一个具体的计算,但在程序的并发执行时,可能有多用户共享使用同一个程序,但处理(计算)的对象却是不同的,例如,在多用户环境下,可能同时有多个用户调用C语言的编译程序,这就是典型的一个程序对应多个用户源程序的情况。,程序并发执行的特点,程序与计算不再一一对应示例,程序A和B在执行过程中都调用了程序C,程序并发执行的特点,三、程序并发执行可以相互制约在多道程序设计
11、的环境下,程序是并发执行的。即系统中有多道程序在“同时”执行,这些程序之间要共享系统的资源,程序之间有合作(通信)的关系。合作与竞争产生一系列的矛盾,这些矛盾实际上是一种相互制约,有直接的,也有间接。注意区别不能同时与有先后次序两种制约。,程序并发执行的特点,程序并发执行的相互制约示例,并发活动进程的引人,操作系统的特性之一是并发与共享,即在系统中(内存)同时存在几个相互独立的程序,这些程序在系统中既交叉地运行,又要共享系统中的资源,这就会引起一系列的问题,包括:对资源的竞争、运行程序之间的通信、程序之间的合作与协同等符。要解决这些问题,用程序的概念已经不能描述程序在内存中运行的状态,必须引人
12、新的概念进程。,进程的定义,行为的一个规则叫做程序,程序在处理机上执行时所发生的活动称为进程(Dijkstra)。进程是这样的计算部分,它是可以和其它计算并行的一个计算。(Donovan)进程(有时称为任务)是一个程序与其数据一道通过处理机的执行所发生的活动。(Alan.C.Shaw)进程是执行中的程序。(Ken Thompson and Dennis Ritchie)进程,即是程序在并发环境中的执行过程。,进程与程序的区别(1),进程是动态概念;程序是静态概念进程具有并发性,宏观上同时运行;程序本身具有顺序性,程序的并发执行是通过进程实现的进程具有独立性,是一个能独立运行的单位,是系统资源分
13、配的基本单位,是运行调度的基本单位;程序本身没有此特性,进程与程序的区别(2),进程和程序无一一对应关系,一个进程可顺序执行多个程序;一个程序可由多个进程共用进程异步前进,会相互制约;程序不具备此特性进程实体具有一定结构,组成进程映象;程序没有这种结构,进程与程序的区别示例,例子:光盘(CD、VCD、DVD)光盘(程序)-放光盘的活动(进程),理解进程概念,进程的运行状态及其变迁进程的组成进程映像进程环境,进程的运行状态及其变迁,进程在系统中的活动规律是:执行-暂停-执行进程的运行状态反映进程的动态性。进程的三种基本状态:运行状态 就绪状态 封锁状态(又称不可运行、挂起),进程的三种基本状态,
14、运行状态:进程得到CPU控制权,它的程序正在运行。(在系统中,总只有一个进程处于此状态)就绪状态:已经准备就绪,一旦得到CPU,就立即可以运行。(有多个进程处于此状态)封锁状态:正在等待某个事件的发生(如等待I/O的完成),而暂停执行,这时,即使给它CPU时间,它也无法执行。,进程的状态变化,就绪,运行,挂起,进程的组成,基本内容的确定?,进程与PCB的关系,每个进程有唯一的PCB 系统中所有进程都有自己的PCB操作系统依据PCB管理进程,进程与PCB的关系,操作系统利用PCB实现进程的动态和并发 PCB是进程存在的唯一标志,Pcb表组织,a,b,-1,pcb1,N个,pcb2,pcbi,Pc
15、b-addr,?,空间大小?,?,UNIX的进程映像,进程状态变迁关系进程映像:PCB的实现、核心栈与用户栈(图2-10 UNIX进程映像结构),进程环境,用户级环境寄存器环境系统级环境,1、进程与程序的区别2、进程的组成3、进程的同步与互斥,进程控制原语,Fork()Wait(stat_addr)Exitexec,进程在活动中会相互制约,所有进程都是相互独立的 进程以异步方式并发执行,同步,同步是进程间共同完成一项任务时直接发生相互作用的关系,同步进程间具有合作关系 在执行时间上必须按一定的顺序协调进行,互斥,互斥是并发执行的多个进程由于竞争同一资源而产生的相互排斥的关系,互斥进程彼此在逻辑
16、上是完全无关的 它们的运行不具有时间次序的特征,临界资源和临界区信号量P、V操作,临界资源,一次仅允许一个进程使用的共享资源 如:打印机、内存单元、表格,临界区,在每个进程中访问临界资源的那段程序 有限进入原则唯一原则有限离开原则,进程间的通信,临界资源和临界区信号量P、V操作,信号量,信号量是一种数据结构 一般由两个成员组成:,数值指针,?,信号量,一般说来,信号量的值与相应资源的使用情况有关 信号量的值仅由P、V操作改变,进程间的通信,临界资源和临界区信号量P、V操作,P、V操作都是原语,P:申请一个单位资源(P47)V:释放一个单位资源(P47),P操作,P(s):,若S0,入等待队列,
17、若S=0,继续,取s值减1,V操作,V(s):,若S=0,唤醒一等待队列进程,若S0,继续,取s值加1,用P、V原语实现互斥,例:打印机分配互斥信号量mutex(初值为1)Pa为分配进程Pb为释放进程,Pa:.P(mutex)分配打印机(读写分配表)V(mutex).,Pb:.P(mutex)释放打印机(读写分配表)V(mutex).,用P、V原语实现简单同步,例:供者和用者对单缓冲区的同步信号量:S1缓冲区空否(初值为1)S2缓冲区满否(初值为0),供者进程L1:P(S1)启动读卡机 收到输入结束中断 V(S2)goto L1,用者进程L2:P(S2)从缓冲区取出信息 V(S1)goto L
18、2,用P、V原语实现同步,设上例中缓冲区容量为n,分析信号灯的设置与状态变化范围(生产者-消费者问题P49),其它进程通信方式,信号量集方式管程消息缓冲通信,UNIX中的进程通信,Sleep 和wakeup进程跟踪S_5的ipc:消息机制,共享内存,信号量。,处理机管理,目标:提高CPU的有效运行时间如何实现?根据CPU的特点和进程管理的需要来设计管理方法,CPU资源的特点,是一种时间资源具有唯一性与独占性影响系统效率的关键因素进程运行的必备资源,CPU效率的影响因素,并发总有请求CPU的进程CPU时间分片在效率与交互性上权衡现场交换代价只做必须做的工作,处理机的二级调度,宏观作业调度:算法复
19、杂、间隔长、宏观环境微观进程调度:算法简单、调度频繁、微观状态,作业调度,作业调度的主要任务是完成作业从后备状态到执行状态和从执行状态到完成状态的转变。作业调度功能:记录已进入系统的各作业的情况(JCB,Job Control Block);按一定的调度算法,从后备作业中选择一个或几个作业进入系统内存;为被选中的作业创建进程,并且为其申请系统资源;作业加束后作善后处理工作。,作业控制块(JCB),每个作业进入系统时由系统为其建立一个作业控制块JCB(Job Control Block),它是存放作业控制和管理信息的数据结构,主要信息见下图。,调度性能的衡量,作业调度算法规定了从后备作业中选择作
20、业进入系统内存的原则,这些原则的性能如何,就是本节所讨论的问题。确定调度算法时应考虑的因素应与系统的整体设计目标一致考虑系统中各种资源的负载均匀保证作业的执行对一些专用资源的使用特性的考虑,调度性能的衡量,调度性能的衡量通常采用平均周转时间和带权平均周转时间作业的周转时间:ti=tci-tsiti:作业周转时间tci:作业完成时间tsi:作业提交时间,调度性能的衡量,先来先服务调度算法和短作业优先调度算法,进程调度,调度与进程控制和进程通信的功能有密切的联系,当一个进程阻塞时,这种进程将进入相应的等待队列中,并让出CPU,调用进程分派程序选择一个就绪进程占用CPU;当一进程被唤醒时,这种进程将
21、插入到就绪进程队列中。在一般的操作系统教材中把上述功能称为进程调度。,调度/分派结构,处理机分配由调度和分派两个功能组成。调度:组织和维护就绪进程队列。包括确定调度算法、按调度算法组织和维护就绪进程队列。分派:是指当处理机空闲时,从就绪队列队首中移一个PCB,并将该进程投入运行。,调度/分派结构,pcb1,scheduler,susp,wakeup,receive,pcb2,pcb3,pcb4,dispatcher,cpu,Ready-q,调度/分派结构,pcb2,scheduler,susp,wakeup,receive,pcb5,pcb3,pcb4,dispatcher,cpu,Ready
22、-q,pcb1,进程调度功能,保护现场入就绪队列算法实现处理机分派恢复现场,进程调度的功能,记录和保持系统中所有进程的有关情况和状态特征 有关进程调度的信息是记录在PCB中的,在进程调度中用到的主要是进程的状态、调度优先级(优先数)、就绪进程队列等。,进程调度的功能,决定分配(处理机)策略确定进程调度的策略,例如,先来先服务、优先数调度策略,调度策略的不同,组织就绪进程队列的方式也不同。先来先服务调度策略,就绪队列要按等待时间大到小的顺序排队;优先数调度,则就绪进程队列要按优先数的升疗(或降序)的方式排队。等等。,进程调度的功能,实施处理机的分配总而言之,进程调度包括:调度算法的选择(调度算法
23、)调度时机的选择(调度时机)实施进程调度(调度程序),进程调度的功能,调度时机(UNIX系统中):(1)进程自动放弃处理机:当进程进入高低优先级睡眠状态时(在sleep()程序中);在进程进入暂停状态时(在stop()程序中);进程进入僵死状态时(在exit()程序中);,进程调度的功能,在中断自陷总控程序中,当先前态是用户态,且runrun标志大于0,则进行强迫调度,强行剥夺现运行进程的处理机,转进程调度程序。runrun标志大于0是说明系统中处于就绪状态的进程的优先级高于现运行进程的优先级,这时要进行强迫调度,出现这种情况有两种可能:高低优先级睡眠进程被唤醒后其优先级高于现运行进程;当一个
24、进程占用一段时间的CPU后,它的优先级要降低,造成现运行进程的优先级低于系统中的其它就绪进程(时间片到是其中的一种情况)。(2)强迫调度,调度方式,优先数高者进程是否抢占正在运行进程资源非剥夺方式剥夺方式选择可抢占策略:优先数+抢占标志(u,v),进程调度的功能,实施进程调度的程序称为进程调度程序(或称调度程序),在通常的操作系统原理中,该程序属于系统进程的执行程序,有的操作系统是把进程调度程序作一个特别的处理,如早期的操作系统中把进程调度程序称为交通控制程序,不属于系统中的任何进程。在UNIX系统中,进程调度程序swtch()分属个不同的进程,即调用swtch()的进程、让出处理机的进程、0
25、进程、被调度到的进程。,调度性能的衡量,选择策略时考虑因素整体目标、负载均衡、资源特性、用户满意调度性能指标平均周转时间,平均带权周转时间CPU利用率吞吐量就绪等待时间响应时间,调度策略,先来先服务调度短作业优先调度响应比高者优先调度优先数调度均衡调度多级队列法多级反馈队列法,进程优先数调度算法,优先数调度算法是目前操作系统广泛采用的一种进程调度算法,这种算法按照某种原则由系统(或用户、或系统与用户结合)赋予每个进程一个优先数,在处理机空闲时,进程调度程序就从就绪进程中选择一个优先数最大(或者最小)的进程占用CPU(该进程就从就绪状态转换成运行状态)。采用这种调度算法的关键是如何确定进程的优先
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 操作系统 原理 PPT
链接地址:https://www.31ppt.com/p-6118673.html