1、操作系统概述(操作系统笔记)

这里是学习了北大的操作系统原理课程做的笔记,这门课有一个好处就是基本上按照《现代操作系统》这本书来讲的,可以对照着看,入门之后最好还是看看MIT6.824,实际操作一下。

一、操作系统做了什么

通过一个例子进行说明:给出一个c程序helloworld

#include<stdio.h>
  int main(int argc, char *argv[]){
    puts(“hello world”);
    return 0;
  }

说明:其功能就是在标准的显示器上显示一个字符串。下面看此程序的执行过程。

  • 首先用户要告诉操作系统执行此程序:
    如何告知?比如我们可以在命令行输入相应的命令或者双击此程序的图标。

  • 操作系统接到用户的请求之后就会到磁盘上找到此程序的相关信息,检查其类型是否是可执行文件;并通过程序首部信息,确定代码和数据在可执行文件中的位置并计算出对应的磁盘块地址。

  • 为了要执行此程序,操作系统首先要创建一个新的进程,并将此程序的可执行文件映射到该进程结构,表示由该进行执行此程序。之后操作系统为此程序设置CPU上下文环境,并跳到程序开始处(假设调度程序选中了此程序)。

  • 当在执行程序的第一条指令的时候会发生缺页异常:因为程序在执行的时候,先要将程序的代码和数据装入内存,CPU才能够去执行。但是此时还没有读入内存,于是硬件机制就会捕获此异常,并且把控制权交给操作系统。

  • 操作系统管理了系统中的内存,当然内存有很多中,比如这里我们拿页式管理方案的话,内存就会有很多的物理页面,操作系统的内存管理模块就会分配一页空闲物理内存,并且根据前面计算出的磁盘块地址把程序代码读到内存中,然后继续执行程序。有时候程序可能很大,所以一次分配可能不够,于是在执行过程中可能产生多次缺页异常。

  • 然后程序执行puts函数(系统调用)。而puts函数是一个系统调用,于是控制权又交给了操作系统。

  • 操作系统找到要将字符串送往的显示设备,通常设备是由一个进程控制的,所以,操作系统将要写的字符串送给该进程。

  • 控制设备的进程告诉设备的窗口系统它要显示的字符串,窗口系统确定这是一个合法的操作,然后将字符串转换成像素,将像素写入设备的存储映像区。

  • 然后视频硬件将像素转换成显示器可以接收的一组控制/数据信号。显示器然后解释此信号,激发液晶屏。

总结

  • 从用户的角度看上述执行过程


    1

    这是从用户角度来看的程序运行过程。

  • 从操作系统的角度来看就是,如果操作系统选中了一个程序,那么就去调度此程序执行,程序执行过程中会不断的陷入操作系统,由操作系统去提供一些服务,当服务完成之后操作系统又会去调用程序去执行。


    2

二、操作系统的定义和作用

2.1 定义

操作系统是计算机系统中的一个系统软件,是一些程序模块的集合:

  • 它们能以尽量有效、合理的方式组织和管理计算机的软硬件资源
  • 合理地组织计算机的工作流程,控制程序的执行并向用户提供各种服务功能
  • 使得用户能够灵活、方便地使用计算机,使整个计算机系统高效运行。

2.2 操作系统管的作用

2.2.1 资源的管理者:有效

这是从自底向上看的,即从操作系统内部来看。

  • 硬件资源:CPU、内存、设备等
  • 软件资源:磁盘上的文件、各类管理信息等。

1、怎样管理资源?

  • 跟踪记录资源的使用状况:这是使用各类数据结构来跟踪的,跟踪的信息有如哪些资源空闲,分配给谁使用,允许使用多长时间等。
  • 确定资源分配侧露:即需要相关的算法。如静态分配策略(进程需要的资源一开始就分配好,会导致浪费),动态分配策略(在一个进程的执行过程中什么时候需要什么时候分配)
  • 实施资源的分配和回收
  • 提供资源利用率
  • 保护资源的使用
  • 协调多个进程对资源请求的冲突

2、从资源管理的角度:五大基本功能

  • 进程/线程管理(CPU管理):进程线程状态、控制、同步互斥、通信、调度、…
  • 存储管理:分配/回收、地址转换、存储保护、内存扩充、…
  • 文件管理:文件目录、文件操作、磁盘空间、文件存取控制、…
  • 设备管理:设备驱动、分配回收、缓冲技术、…
  • 用户接口:系统命令、编程接口

2.2.2 向用户提供各种服务:方便使用

操作系统是各种系统服务的提供者

  • 在操作系统之上,从用户角度来看:
    操作系统为用户提供了一组功能强大。方便易用的命令或系统调用
  • 典型服务:
    进程的创建、执行;文件和目录操作;IO设备的使用;各类统计信息;…

2.2.3 对硬件机器的扩展:扩展能力

操作系统是硬件之上的第一层软件,我们使用操作系统将硬件屏蔽,而让操作系统给我们提供操作各类硬件的接口。因为与硬件相关的工作是很复杂和繁琐的。于是操作系统就是对硬件机器的扩展:

  • 操作系统在应用程序与硬件之间建立了一个等价的扩展机器(虚拟机器)
  • 对硬件抽象,提高可移植性;比底层硬件更容易编程

三、操作系统的主要特征

主要特征:并发、共享、虚拟、随机

3.1 并发

指处理多个同时性活动的能力。

  • 由于并发将可能引起很多问题:活动切换、保护、相互依赖的活动间的同步

  • 在计算机系统中同时存在多个程序运行,但cpu上:

    • 宏观上:这些程序同时在执行
    • 微观上:任何时刻只有一个程序真正在执行,即这些程序在cpu上是轮流执行的
  • 并行:与并发类似,但多指不同程序同时在多个硬件部件上执行,比如多cpu系统。

3.2 共享

操作系统与多个用户的程序共同使用计算机系统中的资源。
操作系统要对系统资源进行合理的分配和使用,资源在一个时间段内交替被多个进程使用。

  • 互斥共享(如打印机)
  • 同时共享(如可重入代码、磁盘文件)
  • 问题:资源分配难以达到最优化,如何保护资源?

3.3 虚拟

  • 一个物理实体(如cpu)映射为若干个对应的逻辑实体:分时或分空间
  • 虚拟是操作系统管理系统资源的重要手段,可提高资源利用率

3.4 随机

操作系统必须随时对以不可预测的次序发生的事件进行响应并处理

  • 进程的运行速度不可预知
  • 难以重现系统在某个时刻的状态(包括运行中的错误)

四、典型的操作系统架构

4.1 Windows架构

3

4

5

说明:以上是Windows架构中一步步抽象的结果。这里不细说。

4.2 UNIX架构

6

4.3 Linux架构

7

说明:这里只给出了内核组件。

4.4 Android架构

8

五、操作系统分类

5.1 传统分类

5.1.1 操作系统的发展历程

  • 操作系统发展是随着计算机硬件技术、应用需求的发展、软件新技术的出现而发展。
    目标:充分利用硬件和提供更好的服务
    发展进程:大型机--->个人计算机--->网络--->移动计算机--->云计算--->泛在计算(物联网)--->机器人

  • 分类
    批处理操作系统
    分时系统
    实时操作系统
    个人计算机操作系统
    网络操作系统
    分布式操作系统
    嵌入式操作系统

5.1.2 批处理操作系统

  • 工作方式
    1、 用户将作业交给系统操作员
    2、 系统操作员将许多用户的作业组成一批作业,输入到计算机系统中,在系统中形成一个自动转接的连续的作业流
    3、 启动操作系统
    4、 系统自动、依次执行每个作业
    5、 由操作员将作业结果交给用户

  • 目标
    提高资源利用率,增加作业处理吞吐量

  • 作业包括
    用户程序
    数据
    作业说明书(用作业控制语言编写)

  • 成批
    通常由若干作业组成,用户提交作业后只能等待处理结果,不能干预作业的执行

  • 处理
    对一批作业中的每个作业进行相同的处理:从磁带读入用户作业和编译连接程序,编译连接用户作业以生成可执行程序;启动执行;输出结果

  • 问题
    慢速的输入输出处理直接由主机来完成,输入输出时,cpu处于等待状态

  • 解决方案
    卫星机:完成面向用户的输入输出,中间结果暂存在磁盘上

5.1.3 分时操作系统

  • 时间片
    操作系统将cpu的时间划分为若干个片段,成为时间片。

    • 操作系统以时间片为单位,轮流为每个终端用户服务,每次服务一个时间片
    • 其特点是利用人的错觉,使用户感觉不到计算机在服务其他人
  • 目标
    及时响应(依据是响应时间)

  • 响应时间
    从终端发出命令到系统给予回答所经历的时间

5.1.4 通用操作系统

  • 分时系统与批处理系统结合
  • 原则:分时优先,批处理在后
    • “前台”:需要频繁交互的作业
    • “后台”:时间性要求不强的作业

5.1.5 实时操作系统

  • 是指使计算机能及时响应外部事件的请求,在规定的严格时间内完成对该事件的处理,并控制所有实时设备和实时任务协调一致地工作

  • 分类
    第一类:实时过程控制(工业控制、航空、军事控制等)
    第二类:实时通信处理(电讯、银行等)

  • 目标
    对外部请求在严格时间范围内做出响应
    高可靠性

5.1.6 个人计算机操作系统

  • 计算机在某一时间内为单用户服务

  • 目标
    界面友好,使用方便,丰富的应用软件

5.1.7 网络操作系统

  • 基于计算机网络:在各种计算机操作系统上按网络体系结构协议标准开发的软件

  • 功能
    网络管理,通信,安全,资源共享和各类网络应用

  • 目标
    相互通信,资源共享

5.1.8 分布式操作系统

  • 分布式系统:或以计算机网络为基础,或以多处理器为基础,基本特征是处理分布在不同的计算机上

  • 分布式操作系统是一个统一的操作系统,允许若干计算机可相互协作共同完成一项任务。操作系统可将各种系统任务在复试系统中任何处理机上运行,自动实现全系统范围内的任务分配、自动调度、均衡各处理机的工作负载。

  • 处理能力增强、速度更快、可靠性强、具有透明性

5.1.9 嵌入式操作系统

完成某些特定的任务

5.2 另一种分类(TANENBAUM)

  • 大型机操作系统
  • 服务器操作系统
  • 多处理机操作系统
  • 个人计算机操作系统
  • 掌上计算机操作系统
  • 嵌入式操作系统
  • 传感器节点操作系统
  • 实时操作系统
  • 智能卡操作系统
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 157,198评论 4 359
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 66,663评论 1 290
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 106,985评论 0 237
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,673评论 0 202
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 51,994评论 3 285
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,399评论 1 211
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,717评论 2 310
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,407评论 0 194
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,112评论 1 239
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,371评论 2 241
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,891评论 1 256
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,255评论 2 250
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,881评论 3 233
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,010评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,764评论 0 192
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,412评论 2 269
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,299评论 2 260

推荐阅读更多精彩内容