操作系统学习笔记(一)

Updated December 25, 2018

操作系统引论

多道程序设计的基本概念

在多道批处理系统中, 用户所提交的作业先存放在外存上, 并且排成一个队列, 称为后备队列, 由作业调度程序按一定的算法, 从后备队列中选择若干个作业调入内存, 使它们共享CPU和系统中的各种资源. 由于同时在内存中装有若干道程序, 可以利用程序在I/O操作时的CPU空挡时间, 使多道程序交替地运行, 这样便可以保持CPU处于忙碌状态.

多道批处理系统的优缺点

  1. 资源利用率高: CPU可以保持忙碌状态, 可提高内存的利用率, 可提高I/O设备的利用率
  2. 系统吞吐量大: CPU和其它资源保持忙碌状态, 作业仅当完成或运行不下去时才进行切换, 系统开销小
  3. 平均周转时间长: 由于作业要排队依次进行处理, 因而作业的周转时间较长
  4. 无交互能力: 用户一旦把作业提交给系统, 直至作业完成, 用户都不能与自己的作业进行交互

操作系统的基本特性

  1. 并发: 指两个或多个事件在同一时间间隔内发生. 这些事件宏观上是同时发生的, 但是微观上是交替发生的. 一个单核处理机同一时刻只能执行一个程序, 因此操作系统会负责协调多个程序交替执行
  2. 共享: 是指系统中的资源可供内存中多个并发执行的进程共同使用
    • 互斥共享方式: 系统中的某些资源, 虽然可以提供给多个进程使用, 但一个时间段内只允许一个进程访问该资源
    • 同时共享方式: 系统中的某些资源, 允许同一个时间段内由多个进程对它们进行访问
  3. 虚拟: 通过某种技术将一个物理实体变为若干个逻辑上的对应物
    • 时分复用技术
    • 空分复用技术
  4. 异步: 在多道程序环境下, 允许多个程序并发执行, 但由于资源有限, 进程的执行不是一贯到底的, 而是走走停停, 以不可预知的速度向前推进, 这就是进程的异步性

系统调用

应用程序通过系统调用请求操作系统的服务.
系统调用是操作系统提供给应用程序(开发人员)使用的接口, 可以理解为一种可供应用程序调用的特殊函数

应用程序 可直接进行系统调用, 也可使用库函数. 有的库函数涉及系统调用, 有的不涉及
编程语言 向上提供库函数. 有时会将系统调用封装成库函数, 隐藏系统调用的一些细节, 使上层进行系统调用更加方便
操作系统 向上提供系统调用
裸机

系统调用的过程

  1. 传递系统调用参数
  2. 执行陷入指令(用户态)
  3. 执行系统调用相应服务程序(核心态)
  4. 返回用户程序
    注意: 陷入指令是在用户态执行的, 执行陷入指令之后立即引发一个内中断, 从而CPU进入核心态. 发出系统调用请求是在用户态, 而对系统调用的相应处理在核心态下进行

中断和异常

发生中断就意味着需要操作系统介入, 开展管理工作. 当中断发生后, CPU立即进入内核态, 当前运行的进程暂停运行, 并由操作系统内核对中断进行处理
中断的分类

  • 内中断(异常): 信号的来源是CPU内部, 与当前执行的指令有关
    • 自愿中断--指令中断
    • 强迫中断(如硬件故障(缺页), 整数除以0)
  • 外中断: 信号来源是CPU外部, 与当前执行的指令无关
    • 外设请求(I/O操作完成发出的中断信号)
    • 人工干预

进程

进程实体: 由程序段, 数据段, PCB三部分构成
进程: 进程实体的运行过程, 是系统进行资源分配和调度的一个独立单位
创建撤销进程, 实质上是创建撤销进程实体中的PCB

PCB(记录型数据结构)

作为独立运行基本单位的标志. 能实现间断性运行方式, 系统可将CPU现场信息保存在被中断进程的PCB中, 供该进程再次被调度执行时恢复CPU现场时使用

  • 进程描述信息: 进程标识符PID和用户标识符UID
  • 进程控制和管理信息: 进程的当前状态, 进程优先级
  • 处理机状态: 处理机的各种寄存器的内容
  • 资源清单: 键盘, 鼠标等
PCB的组织方式

在一个系统中, 通常有数十数百乃至更多的PCB, 为了能对它们加以有效的管理, 应该用适当的方式把这些PCB组织起来

  1. 线性方式: 将系统中所有的PCB都组织在一张线性表中, 将该表的首址存放在内存的一个专用区域中
  2. 链接方式: 把具有相同状态进程的PCB分别通过PCB中的链接字链接成一个队列. 可以形成就绪队列, 若干个阻塞队列和空白队列
  3. 索引方式: 系统根据所有进程状态的不同, 建立几张索引表, 如就绪索引表, 阻塞索引表, 并把各索引表在内存的首地址记录在内存的专用单元中

进程的状态

  1. 就绪态: 已经具备运行条件, 但是由于没有空闲CPU, 暂时不能运行
  2. 执行态: 进程已经占有CPU, 并在CPU上执行
  3. 阻塞态: 指正在执行的进程由于发生某事件暂时无法执行时的状态
  4. 创建态: 由进程申请一个空白PCB, 并向PCB中填写用于控制进程的信息
  5. 终止态: 将PCB清零, 并将PCB返还系统
进程同步

进程同步是对多个相关进程在执行次序上进行协调, 使并发执行的诸进程之间能按照一定的规则共享系统资源.
为了实现对临界资源的互斥访问, 需遵循以下原则:

  1. 空闲让进: 当无进程处于临界区时, 应允许一个请求进入临界区的进程立即进入临界区
  2. 忙则等待: 当已有进程进入临界区时, 其它试图进入临界区的进程必须等待
  3. 有限等待: 对请求访问临界资源的进程, 应保证在有限时间内进入临界区(保证不会饥饿)
  4. 让权等待: 当进程不能进入临界区时, 应立即释放处理机, 以免进程陷入忙等状态

硬件方法实现进程互斥:

  1. 关中断
  2. Test and Set指令
  3. Swap指令

信号量机制
可以用一个信号量表示系统中某种资源的数量, 用户进程可以通过使用操作系统提供的一对原语来对信号量进行操作.

  • 整型信号量
int s = 1;
void wait(int s){
      while(s <= 0);
      s = s-1;
}
void signal(int s){
      s = s+1;
}
  • 记录型信号量
//记录型信号量的定义
typedef struct{
       int value; // 剩余资源数
       struct process *L; // 等待队列
}semaphore;

void wait(semaphore *s){
    s->value--;
    if(s->value < 0)block(s->list);
}
void signal(semaphore *s){
    s->value++;
    if(s->value <= 0)wakeup(s->list);
}
  • 生产者消费者问题
int in = 0, out = 0; item buffer[n];
semaphore mutex = 1, empty = n, full = 0;
void producer(){
    do{
        producer an item nextp;
        wait(empty); wait(mutex);
        buffer[in] = nextp;
        in = (in + 1) % n;
        signal(mutex); signal(full);
    }while(True);
}
void consumer(){
    do{
        wait(full); wait(mutex);
        nextc = buffer[out];
        out = (out + 1) % n;
        signal(mutex); signal(empty);
        consumer the item in nextc;
    }while(True);
}
  • 哲学家进餐问题
semaphore chopstick[5] = {1, 1, 1, 1, 1};
semaphore mutex = 1; //互斥地取筷子
Pi(){ //i号哲学家的进程
  while(1){
      P(mutex); P(chopstick[i]); //拿左
      P(chopstick[(i+1)%5]); //拿右
      V(mutex);
      吃饭
      V(chopstick[i]);
      V(chopstick[(i+1)%5]);
      思考
   }
}
进程通信

指进程之间的信息交换
高级通信机制:

  1. 共享存储器系统: 相互通信的进程共享某些数据结构或共享存储区
  2. 管道通信系统: 管道, 是指用于连接一个读进程和一个写进程以实现它们之间通信的一个共享文件, 又叫pipe文件. 写进程以字符流形式将大量的数据送入管道, 读进程则从管道中接收数据.
  3. 消息传递系统: 不必借助任何共享存储区或数据结构, 而是以格式化的消息为单位, 将通信的数据封装在消息中, 并利用操作系统提供的一组通信命令原语, 在进程间进行消息传递
  4. 客户机-服务器系统
线程

引入进程的目的是为了使多个程序能并发执行, 以提高资源利用率和系统吞吐量.
引入线程的目的是为了减少程序在并发执行时所付出的时空开销.
线程是一个基本的CPU执行单元, 也是程序执行流的最小单位
线程是调度的基本单位
由于进程是一个资源的拥有者, 因而在创建, 撤销和切换中, 系统必须为之付出较大的时空开销. 线程间并发, 如果是同一进程内的线程切换, 则不需要切换进程环境, 系统开销小

处理机调度与死锁

调度的实质是一种资源分配, 处理机调度是对处理机资源进行分配.
饥饿: 某进程/作业长期得不到服务

  • 作业调度(高级调度):
    根据某种算法, 从外存上处于后备队列的作业中挑选一个或多个作业, 给它们分配内存等资源, 建立相应的进程(建立PCB).
  • 内存调度(中级调度):
    引入中级调度的目的是提高内存利用率和系统吞吐量
    中级内存实际上就是存储器管理中的对换功能
    把那些暂时不能运行的进程调至外存等待, 此时进程的状态称为挂起状态, 当它们已具备运行条件且内存又稍有空闲时, 由中级调度决定重新调入内存.
  • 进程调度(低级调度):
    按照某种算法, 从就绪队列中选择一个进程为其分配处理机
    进程切换是指一个进程让出处理机, 另一个进程占有处理机的过程, 对原来运行的进程保存各种数据, 对新的进程恢复各种数据

处理机的利用率
CPU的利用率=CPU有效工作时间/(CPU有效工作时间+CPU空闲等待时间)

调度算法

  • 先来先服务(first-come first-served)调度算法
    该算法可用于作业调度和进程调度, 系统按照作业到达的先后次序来进行调度, 优先考虑在系统中等待时间最长的作业
  • 短作业优先(short job first)调度算法
    该算法以作业/进程的长短来计算优先级, 作业/进程越短, 优先级越高.
    对短作业有利, 长作业不利, 还可能造成饥饿.
  • 优先级调度算法(priority-scheduling algorithm)
    在优先级调度算法中, 基于作业的紧迫程度, 由外部赋予作业相应的优先级, 调度算法根据该优先级进行调度.
  • 高响应比优先调度算法(Highest Response Ratio Next)
    为每个作业引入一个动态优先级, 即令优先级随等待时间延长而增加, 避免了长作业饥饿的问题. 该优先级的变化规律可描述为: 优先权=(等待时间+要求服务时间)/要求服务时间
  • 基于时间片的轮转(round robin)调度算法
    系统根据FCFS策略, 将所有的就绪进程排成一个就绪队列, 并设置每隔一定时间间隔(如30ms)产生一次中断, 激活系统中的进程调度程序, 如果进程尚未运行完毕, 调度程序把它送往就绪队列的末尾, 将CPU分配给队首进程.
  • 多队列调度算法
    该算法将系统中的进程就绪队列从一个拆分为若干个, 将不同类型或性质的进程固定分配在不同的就绪队列, 不同的就绪队列采用不同的调度算法
  • 多级反馈队列(multileved feedback queue)调度算法
  1. 在系统中设置多个就绪队列, 并为每个队列赋予不同的优先级. 第一队列优先级最高, 第二个次之. 该算法为不同队列中的进程所赋予的执行时间片的大小也不相同, 在优先级越高的队列中, 其时间片越小.
  2. 新进程进入内存后, 先将其放入第一队列的末尾, 每个队列都采用FCFS算法, 当轮到该进程执行时, 若用完时间片进程还未结束, 则将该进程放入下一级队列队尾
  3. 只有第k级队列为空时, 才会为第k+1级队头的进程分配时间片

死锁

在并发环境下, 各进程因竞争资源而造成的一种互相等待对方手里的资源, 导致各进程都阻塞, 都无法向前推进的现象

  • 产生死锁的必要条件
    互斥条件, 请求和保持条件, 不可抢占条件, 循环等待条件
  • 处理策略
    1. 预防死锁: 破坏产生死锁的四个必要条件
    2. 避免死锁: 银行家算法
    3. 死锁的检测与解除
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,875评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,569评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,475评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,459评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,537评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,563评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,580评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,326评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,773评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,086评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,252评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,921评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,566评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,190评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,435评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,129评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,125评论 2 352

推荐阅读更多精彩内容

  • 1. 基础知识 1.1、 基本概念、 功能 冯诺伊曼体系结构1、计算机处理的数据和指令一律用二进制数表示2、顺序执...
    yunpiao阅读 5,287评论 1 22
  • 操作系统概论 操作系统的概念 操作系统是指控制和管理计算机的软硬件资源,并合理的组织调度计算机的工作和资源的分配,...
    野狗子嗷嗷嗷阅读 11,917评论 3 34
  • # 第一章复习题答案p3 1、计算机系统由哪些部分组成? 2、什么是计算机的操作系统?答:操作系统是计算机的一种系...
    叛逆闲人阅读 3,334评论 0 0
  • 内核架构 内核的基础知识 所有现代的操作系统在设计师都包含一个称为内核(kernel)的组件,是整个系统的核心。内...
    CoderKo1o阅读 2,763评论 1 4
  • 我要买若若的封!我要约稿!我要脱贫!!! 所以有偿做封(๑•̀ㅂ•́)و✧
    宇宙第一咔吹阅读 203评论 9 2