操作系统结构和程序设计

上传人:宝路 文档编号:48347269 上传时间:2018-07-14 格式:PPT 页数:32 大小:142.37KB
返回 下载 相关 举报
操作系统结构和程序设计_第1页
第1页 / 共32页
操作系统结构和程序设计_第2页
第2页 / 共32页
操作系统结构和程序设计_第3页
第3页 / 共32页
操作系统结构和程序设计_第4页
第4页 / 共32页
操作系统结构和程序设计_第5页
第5页 / 共32页
点击查看更多>>
资源描述

《操作系统结构和程序设计》由会员分享,可在线阅读,更多相关《操作系统结构和程序设计(32页珍藏版)》请在金锄头文库上搜索。

1、操作系统结构和程序设计数学与计算机学院硬件教研室操作系统编程的发展在九十年代以前,程序员的精力集中于完成任务的过程,而不是用户与该过程的交互方式,过去评价一个软件的好坏往往是注意源程序的短小精悍和执行的快速性。快速的、清晰的编程是许多程序员努力要达到的理想境界。Windows操作系统将用户与计算机的交互方式的设计(即人机界面设计)放到了非常重要的位置。同时,Windows为不同形式的高层次交互提供了相应的机制:应用程序之间、操作系统和应用程序之间、公共的共享代码库和数据库之间。编程语言简史机器语言: 以二进制代码“0”、“1”组成的机器指令集合;汇编(Assembler)语言:以助记符表示机器

2、指令功 能,例如,JOVIAL、forth;高级语言:接近人类语言(英语)和数学语言的计算 机语言,例如,BASIC、FORTRAN、Pascal、C、 FoxBASE、ORACLE等;进程(Process)概念:例如,UNIX Shell、TCL、 PERL和Marvel等;面向对象的语言:例如C+、Visual BASIC、java等 ;新范例计算机语言:例如ML、Smalltalk、Eiffel等;不同应用领域的计算机语言科学研究: 例如:FORTRAN、ALGOL、BASIC、APL、 Pascal、C、C+、AUTOCAD等; 商业: 例如:COBOL、C、PL/I、4GLs、和sp

3、readsheet 等; 系统: 例如:Assembler、JOVIAL、Forth、C、C+、 Ada、java等; 出版: 例如:TeX、Postscript、word、WPS、和 processing等; 人工智能(AI,artificial intelligence): 例如:LISP、SNOBOL和Prolog等。结构设计的目标计算机操作系统一般都有两种运行状态,即用户态(user mode)和核心态(kernel mode)。计算机操作系统的结构设计一般包括内结构和外结构两种结构。传统操作系统内结构是指内部程序模块的层次结构,每一层由若干数量不等的程序模块组成。例如,早期的UNIX

4、操作系统版本,如图所示。结构设计的目标作业管理文件管理设备管理进程控制和通讯存储管理中断处理、进程调度和P、V操作等图 传统计算机操作系统的内结构(层次结构)结构设计的目标当计算机操作系统内的程序模块运行时,机器处于核心态,其它程序运行时,机器处于用户态,包括操作系统以外的其它系统程序与用户程序一样,都是运行在用户态下而不是运行在核心态下,而可以统称为用户态程序,因而用户程序仅是用户态程序中的一部分。区分用户态和核心态两种运行状态,其目的是使操作系统有一定的特权,使系统运行比较安全可靠。设计目标正确性:实现功能的正确性;安全可靠性:系统工作稳定,不容易被破坏,特别是用户的不正常工作状态不致影响

5、系统垮台;可扩充性和可移植性:能适应较大范围工作的运行环境、硬件平台的要求;易维护性:系统具有的自动修补能力强。分层原则1、层次设计方法从两个不同方向进行:u1)自底向上:底层裸机经某种软件层的扩充形成最终目标系统即宿主系统(操作系统),由底层(0层)扩展到N层顶端。例如,早期是先有微机硬件,再设计合适的操作系统。u2)自顶向下:已知目标N层用户要求,逐级向下进行设计。例如,Windows的图形控制界面。分层原则2、各层间仅有单向依赖关系,层间独立,结构清晰易懂。u一般是有序分层法,例如,上层能调用下层,下层不能调用上层;外层能调用内层,内层不能调用外层,避免产生环路等。其中又可分为:l1)半

6、序:允许同一层互相调用。l2)全序:不允许同一层内互相调用。分块原则1、分块原则一般按功能分块,形成简单的相对独立模块,所编写的程序模块接口应有比较明确的通讯规则,模块间形成转接、相互依赖甚至循环。2、进程的观点用进程的观点进行操作系统设计是继中断概念后的又一重大突破,也就是计算机在执行时不是以一条一条的指令为单元执行,而是以一组特殊指令执行。分块原则3、模块及模块化程序设计u1)模块及模块化模块化是为了获得使用上的灵活性和多样性,是采用标准的可兼容的单元构成系统的一种方法。u2)模块化程序设计模块化程序设计是把一个大的软件系统划分为若干部分,使各部分之间的交往最少,且各自成为具有一定独立功能

7、的程序模块,然后可以对系统中每一部分单独进行设计。分块原则4、模块化程序设计的目的1)使人们确信程序模块的正确性,才能保证所构成的大型软件系统的正确性;2)各模块尽可能具有较大的独立性,以便能方便地把不同场合下写成的程序模块组合成软件系统。5、模块的两个属性和概念1)模块程序是相关过程的集合,通常可用树状控制流程来描述;2)每个模块可以由它的输入链路接受数据,并以某种方式变换它,把所得的结果经由它的输出链路发送到 其它模块。模块接口法的设计步骤1、按照结构设计的原则,把一个大型软件系统,分成若干个具有一定独立性和大小的模块,每个模块可以解决一部分问题或可实现某种功能,并规定好模块之间的接口。这

8、一步称为系统总体设计。2、进一步明确模块每个模块的内部功能。当模块较大时,同样又可将它进一步细分为若干个子模块。3、当所有的子模块被设计出来后,按照它们的接口关系,把子模块链接在一起组成一个大模块,再链接这些大模块便构成软件系统。模块接口法的优缺点1、模块接口法的优点模块接口法设计方法与非结构设计方法比较, 有如下一些优点:u1)加速了操作系统的研制过程;u2)促进操作系统的日益完善;u3)增加操作系统的灵活性。2、模块接口法的缺点u1)很难保证模块设计的正确性;u2)装配的困难性;u3)模块相对独立性差。层次模块化结构设计的必要性1、结构程序设计的定义 所谓结构程序设计是指为了使程序具有一合

9、理结构 ,以便于保证和验证其正确性而规定的一套程序设计方 法,或者说是“按照一组能增强程序的可阅读性与可维护 性的规则而进行程序设计的方法”。用这种方法所设计的 程序称为结构化程序。2、结构程序设计所包含的内容u1)结构码;u2)逐步求精的设计方法;u3)模块接口法;u4)有序分层法;u5)基于进程和线程等的结构设 计。操作系统的结构模型1、层次模型(layered modularization)层次模块模型包含模块(相对独立)化和模块间接口定义。系统通常按功能划分成一些模块,有时模块很小,进一步按由下而上的顺序从硬件层向上组织在若干层次上或自顶向下地组织。操作系统的结构模型2、整体内核模型(

10、monolithic kernel)内核(功能化的大模块,内部无进程层)强调操作系统对外的整体性和友好界面。并不追求严格的模块化和层次化。通常内核在处理机的核心状态下运行,具备各种特权,而外层用户程序运行于用户状态。当用户程 序请求操作系统服务时,必须通过相应的“访管”或“捕获”指令转入核心态,处理之后再返回用户态。UNIX内核为无序模块结构,模块间无层次概念,允许任意调用。核心虽无进程概念,但它负责中断处理、进程生灭、进程调度和进程通讯,从而在核心以上提供了进程的运行环境。操作系统的结构模型3、进程模型(process-model)系统的基本模块为进程(一个独立的控制流),进程这个概念是对控

11、制流的一种抽象,因此,这种模型具有良好的并发性。除核心以外,操作系统的其它功能都是选择若干进程完成的。操作系统的结构模型4、对象模型(object model)面向对象范型(objectoriented paradigm)是以对客观世界自然的抽象为基础设计。对象(object)是对客观事物的抽象。每个对象由界面和实体两部分组成,界面规定其引入引出部分,实体定义状态和操作的具体实现。操作系统的结构设计1)总体设计设计人员要把注意力集中在全局性问题上,即系统的功能设计和结构设计。功能设计是确定系统应具有的功能和实现该功能所采取的策略。以前的操作系统大都采用传统的模块接口法,近年来有序分层法已开始流

12、行起来,最近又提出具有吸引力的、基于线程的结构设计方法。操作系统的结构设计2)逐步求精在确定操作系统的结构后,便可采用逐步求精的结构程序设计方法来进行程序设计。这方法要求从每个问题的全局出发,逐步精细化、具体化。直到成为一可在机器上执行的程序。具体地说,首先把程序在逻辑上分解为若干子结构,对子结构进行描述,并确定相应的数据基,然后再把子结构进行分为更小的结构,对它进行更细微的描述。该过程一直继续下去,直至构成我们所需要的程序。操作系统的结构设计3)结构码 在逐步求精时,应采用单一入口和单一出口的结构码 来构成程序。事实上,只要有下述三种类型的结构码,即 可构成任何程序的全部流程图。u(a)序列

13、结构码 它是完全由序列语句串在一起构成的,一个复杂的序 列结构可分解为多个较简单的序列结构,如:当过程A结 束后,一定执行过程B。u(b)条件结构码(ifthenelse和ifthen) 它是由一个判定语句和两个序列语句构成,其中“条 件”是布尔表达式。u(c)重复性结构码(whiledo;repeatuntil等) 用于循环控制有序分层法的类型有序分层法是在模块接口法的基础上,将模 块安置在高低不同的层次中,自底向上或子顶 向下进行设计和调试,从而把模块间复杂的依 赖关系改为单向依赖关系,把设计决定的无序 性该为有序性,从而使设计具有可靠的基础。 有序分层结构可分为三种类型:u1)线性有序分

14、层结构;u2)部分有序分层结构;u3)树状分层结构。操作系统的分层原则1)按程序的嵌套情况排成有序的层次;2)把活动频繁的模块和为很多模块所公用的模块放在最低软件层,存储器管理模块设置在较低软件层;3)为获得可移植性和可适应性而设置的软件层,应分别放在较低的层次和最外层。高层调用底层软件的方法在严格的层次结构中,只允许高层调用底层中的软件,决不允许底层调用高层的软件。在高层调用底层软件的方法有:1)高层仅能调用它的下一层中的软件;2)高层能调用所有底层的软件;3)高层能部分地调用底层中的软件。微内核(micro-kernel)结构的概念在层次化结构中,大部分的功能在“内核”中执行。随着功能的扩

15、展,内核逐渐扩大,层次间调用设计大大影响了操作系统设计,功能的扩充、移植、规模的伸缩和安全性等方面出现很多困难。因此产生了微内核结构,只把最基本的操作系统核心功能放在内核中,而把不是最基本功能的服务放在微内核之上,在用户模式中执行。层次内核和微内核的结构如图微内核(micro-kernel)结构的概念用户 文件系统进程通信设备管理进程管理硬件微内核 硬件客 户 端 进 程设 备 驱 动 文 件 服 务进 程 服 务虚 拟 存 储(A)层次内核(B) 微内核图 内核结构示意图 微内核结构的特点微内核技术在概念、结构、功能和实现等方面都与以往的操作系统实现有很大的区别。引入 了许多成熟的技术,例如

16、:客户/服务器(client/server)结构、面向对象技术、对称多处理(symmetric multiprocessing,SMP)等新技术日益实用化。一般地,内核分为微内核与服务器两个层次,微内核提供各种操作系统的公共基础,由服务器提供各种操作系统的子系统以及用户界面。微内核的基本功能微内核的基本功能又称为本质功能,这些基本功能包括内进程通讯(inter-process communination,IPC)、虚拟存储(virtual memory,VM)、任务(tasks)、线程(threads)管理和中断(interrupt)处理等。微内核结构的特点1、统一的接口:在用户态和核心态(微内核)之间 无需进程识别;2、可伸缩性好:能适应硬件更新和应用变化;3、可移植性好:所有与具体机器特征相关的代码, 全部隔离在微内核中,如果操作系统要移植到不同的硬件 平台上,只虚、需修改微内核中极少代码即可;4、实时性好:微内核可以方便地支持实时处理;5、安全可靠性高

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 中学教育 > 教学课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号