zoukankan      html  css  js  c++  java
  • 处理机调度

    处理机调度有三个层次:作业调度(高级调度)、中级调度、进程调度(低级调度)

    作业调度:从外存上将处于后备状态的作业中选一个(或多个)作业,给他们分配内存、输入/输出设备等必要的资源,并建立相应的进程,使他们获得竞争处理机的权利(放到就绪队列中等候)。每个作业只会被调入一次,调出一次。

    中级调度:将内存中暂时不能运行的进程调出到外存上暂存(又称“挂起”),等他们具有再次运行的条件的时候再次调回内存的就绪队列中。

    进程调度:按照某种方式和策略从就绪队列中选一个进程并将处理机分配给它。这是最基本的不可或缺的调度策略。

    在以下情况下不能发生进程的调度和切换:

    • 在处理中断的过程中。中断是系统工作的一部分,逻辑上不属于某一进程,不应被剥夺处理机资源。
    • 进程在操作系统内核程序临界区中。进入临界区后必须加锁,独占式访问共享资源,在解锁前不允许其他任何进程访问。
    • 需要完全屏蔽中断的原子性操作时

    进程的调度和切换分两类:剥夺式调度(抢占式)和非剥夺式调度

    进程调度的几种方法:

    1、先来先服务 FCFS

    不可剥夺,对长作业有利,不利于I/O繁忙的作业,用于批处理可还行,不适合分时和实时系统。

    2、短作业优先 SJF

    对短作业有利,但是可能造成长作业饥饿(很长时间得不到调度)。
    完全没有考虑作业的紧迫程度
    作业的长短是根据用户预估的,不一定准确,用户总喜欢缩短自己的预估时间长度,因此不一定能真的短作业优先
    另外,SJF的平均等待时间、平均周转时间最短。

    3、优先级调度

    可以有剥夺式的,也可以有非剥夺式的。
    根据进程创建后优先级是否可以改变分为静态优先级和动态优先级。

    4、高响应比优先调度

    响应比=(等待时间+要求服务时间)/ 要求服务时间
    

    这方法比较好,长作业和短作业都能够得到调度,不至于产生饥饿,且短作业的优先级相对较高。

    5、时间片轮转

    常用于分时系统,时间片的大小对系统性能影响很大

    6、多级反馈队列调度算法

    结合了前几个算法的优点
    抢占式的
    设置了很多级别的就绪队列,每一级就绪队列内部采用时间片轮转,且第二级队列的时间片比第一级队列的时间片长1倍

    对终端型作业用户:短作业优先
    短批处理作业用户:周转时间较短
    长批处理作业用户:不会长期得不到执行,在前几个队列中可以得到部分执行

  • 相关阅读:
    4. RDMA操作类型
    3. RDMA基本元素
    2. 比较基于Socket与RDMA的通信
    1. RDMA概述
    win10 如何开启hyper-v虚拟机
    将Oracle 当前日期加一天、一小时、一分钟
    github搜索案例(axios、pubsub、fetch)
    Tolist案例(父子传参实现增删改)
    5.key的使用
    4.React生命周期
  • 原文地址:https://www.cnblogs.com/yinyoupoet/p/13287418.html
Copyright © 2011-2022 走看看