操作系统之磁盘调度——SCAN实例讲解

简介: 磁盘是高速、大容量、旋转型、可直接存取的存储设备。它作为计算机系统的辅助存储器,担负着繁重的输入输出工作,在现代计算机系统中往往同时会有若干个要求访问磁盘的输入输出要求。系统可采用一种策略,尽可能按最佳次序执行访问磁盘的请求。由于磁盘访问时间主要受寻道时间T的影响,为此需要采用合适的寻道算法,以降低寻道时间。本实验要求学生模拟设计一个磁盘调度程序,观察调度程序的动态运行过程。通过实验让学生理解和掌握磁盘调度的职能。

要求



一、实验目的:


磁盘是高速、大容量、旋转型、可直接存取的存储设备。它作为计算机系统的辅助存储器,担负着繁重的输入输出工作,在现代计算机系统中往往同时会有若干个要求访问磁盘的输入输出要求。系统可采用一种策略,尽可能按最佳次序执行访问磁盘的请求。由于磁盘访问时间主要受寻道时间T的影响,为此需要采用合适的寻道算法,以降低寻道时间。本实验要求学生模拟设计一个磁盘调度程序,观察调度程序的动态运行过程。通过实验让学生理解和掌握磁盘调度的职能。


二、实验内容:


模拟电梯调度算法,对磁盘进行移臂操作


三、提示及要求:


1、假设磁盘只有一个盘面,并且磁盘是可移动头磁盘。


2、磁盘是可供多个进程共享的存储设备,但一个磁盘每个时刻只能为一个进程服务。当有进程在访问某个磁盘时,其它想访问该磁盘的进程必须等待,直到磁盘一次工作结束。当有多个进程提出输入输出请求而处于等待状态时,可用电梯调度算法从若干个等待访问者中选择一个进程,让它访问磁盘。为此设置“驱动调度”进程。


3、由于磁盘与处理器是并行工作的,所以当磁盘在为一个进程服务时,占有处理器的其它进程可以提出使用磁盘(这里我们只要求访问磁道),即动态申请访问磁道,为此设置“接受请求”进程。


4、为了模拟以上两个进程的执行,可以考虑使用随机数来确定二者的允许顺序,程序结构图参考附图:


5、“接受请求”进程建立一张“进程请求I/O”表,指出等待访问磁盘的进程要求访问的磁道,表的格式如下:

| 进程名 | 要访问的磁道 |

|进程id| 磁道号:|


6、 “磁盘调度”的功能是查“请求I/O”表,当有等待访问的进程时,按电梯调度算法(SCAN算法)从中选择一个等待访问的进程,按其指定的要求访问磁道。SCAN算法参考课本第九章。算法模拟框图略。


7、附图中的“初始化”工作包括:初始化“请求I/O”表,设置置当前移臂方向;当前磁道号。并且假设程序运行前“请求I/O”表中已有若干进程(4~8个)申请访问相应磁道。


四、实验报告:


1、实验题目。

2、程序中用到的数据结构及其说明。

3、打印源程序并附注释。

4、实验结果内容如下:打印“请求I/O”表,当前磁道号,移臂方向,被选中的进程名和其要求访问的磁道,看是否体现了电梯调度(SCAN)算法。体会与问题。


五、 附图:


20181204171112358.png


理解


上面就是实验要求。

本实验的核心就是对SCAN算法的理解,SCAN被称为梯度算法。因为它不仅兼顾距离的远近还兼顾方向性。

Scan算法思想大致为:


当设备无访问请求时,磁头不动;

当有访问请求时,磁头按一个方向移动,在移 [2] 动过程中对遇到的访问请求进行服务,然后判断该方向上是否还有访问请求,如果有则继续扫描;否则改变移动方向,并为经过的访问请求服务,如此反复。


如下图所示:


20181204171359656.png


代码


这大致就是流程,当然,你可以动态的增加io请求(接受请求)。


附上代码:


import java.util.ArrayList;
import java.util.Comparator;
import java.util.List;
import java.util.Scanner;
public class 磁盘调度 {
  private static void getstatus(Listlist) {
    // TODO 自动生成的方法存根
    System.out.println("进程id: 磁道: 是否调度?:");
    for(int i=0;i list, int index, int cidao) {
    if(index==1)//向左面
    {
      int mid=0;
      for(int i=0;i<=list.size();i )
      {
        if(list.get(i).cidao>cidao&&list.get(i).isdiaodu==false)
        {
          mid=i-1;break;
        }
      }
      while(mid>=0)
      {
        if(list.get(mid).isdiaodu==false)
        {
          io io=list.get(mid);
          io.isdiaodu=true;
          System.out.println("进程" io.id " 磁道:" io.cidao " 已经调度");         
        }
        mid--;
      }
      mid ;
      while(midcidao&&list.get(i).isdiaodu==false)
        {
          mid=i;break;
        }
      }
      while(mid=0)
      {
        if(list.get(mid).isdiaodu==false)
        {
          io io=list.get(mid);
          io.isdiaodu=true;
          System.out.println("进程" io.id " 磁道:" io.cidao " 已经调度");         
        }
        mid--;
      }
    }
  }
  public static void main(String[] args) {
    // TODO 自动生成的方法存根
    Scanner sc=new Scanner(System.in);
    System.out.println("请输入访问磁盘的进程数量");
    int n=sc.nextInt();
    System.out.println("请输入访问进程的id和磁道号");
    Listlist=new ArrayList<>();
    for(int i=0;icompare=new Comparator(
      ) {
        @Override
        public int compare(io o1, io o2) {
          // TODO 自动生成的方法存根
          return o1.cidao-o2.cidao;
        }
  };
  static class io
  {
    int id;
    int cidao;
    boolean isdiaodu;
    public io(int id,int cidao)
    {
      this.id=id;
      this.cidao=cidao;
    }
  }
}

输出案例


测试数据:


20181204173457116.png20181204173512433.png


若有错误的地方,还请大神指正。


目录
相关文章
|
4天前
|
算法 调度 UED
探索操作系统中的进程调度:理论与实践
【9月更文挑战第24天】 在数字世界的心脏跳动着的是操作系统,它像一位精明的指挥家,精心安排每个音符的演奏。本文将带你进入操作系统的内核,一探进程调度的秘密。我们将从简单的批处理系统谈起,穿越时间隧道,见证现代多道程序设计系统的复杂性与优雅。你将看到代码如何赋予理论以生命,理解调度算法背后的哲理。让我们一起跟随甘地的指引,成为我们希望在世界上看到的改变。
|
2天前
|
存储 算法 前端开发
深入理解操作系统:进程调度与优先级队列算法
【9月更文挑战第25天】在操作系统的复杂世界中,进程调度是维持系统稳定运行的核心机制之一。本文将深入探讨进程调度的基本概念,分析不同的进程调度算法,并着重介绍优先级队列算法的原理和实现。通过简洁明了的语言,我们将一起探索如何优化进程调度,提高操作系统的效率和响应速度。无论你是计算机科学的初学者还是希望深化理解的专业人士,这篇文章都将为你提供有价值的见解。
|
6天前
|
算法 Unix 调度
探索操作系统的心脏:进程管理与调度
【9月更文挑战第22天】在数字世界的复杂迷宫中,操作系统(OS)是指引路径的明灯。本文深入探讨了操作系统的核心功能——进程管理和调度机制,揭示了它们如何确保多任务同时流畅运行。通过比喻和简化的解释,我们将解码进程生命周期的奥秘,并理解调度算法如何在公平性和效率间取得平衡。无论你是技术新手还是资深开发者,这篇文章都将带给你新的视角和深刻的见解。
|
8天前
|
算法 Unix Linux
深入理解操作系统:进程管理与调度
【9月更文挑战第20天】在探索计算机科学的核心,我们不可避免地会遇到操作系统——这一复杂而精妙的软件系统。本文将深入剖析操作系统的关键组成部分之一:进程管理与调度。我们将通过浅显易懂的语言和直观的代码示例,逐步解开进程生命周期的奥秘,并探讨如何高效地进行进程调度。无论你是初学者还是有一定基础的开发者,这篇文章都将为你提供新的视角和深入的理解。
33 13
|
3天前
|
机器学习/深度学习 算法 物联网
探究操作系统的心脏:调度算法的演变与优化
本文旨在深入探讨操作系统中核心组件——调度算法的发展脉络与优化策略。通过分析从单任务到多任务、实时系统的演进过程,揭示调度算法如何作为系统性能瓶颈的解决关键,以及在云计算和物联网新兴领域中的应用前景。不同于传统摘要,本文将注重于概念阐释与实例分析相结合,为读者提供直观且全面的理解视角。
|
7天前
|
算法 调度
深入理解操作系统:进程调度与优先级反转
【9月更文挑战第21天】在操作系统的心脏跳动着的,是进程调度器。它决定了哪个进程运行,何时运行,以及如何优雅地共享CPU资源。本文将通过浅显易懂的语言和直观的代码示例,探索进程调度的奥秘,揭示优先级反转问题及其解决方案,带领读者领略操作系统中这一精妙绝伦的设计。
|
9天前
|
监控 算法 程序员
探索操作系统的核心:进程管理与调度
【9月更文挑战第19天】本文深入浅出地探讨了操作系统中至关重要的一环——进程管理与调度。通过直观的语言和生动的案例,我们将了解进程是什么,它们如何被操作系统所管理,以及调度算法对系统性能的影响。文章旨在为读者揭示操作系统背后的秘密,同时提供实用的代码示例来加深理解。无论你是计算机专业的学生还是对操作系统有兴趣的程序员,这篇文章都将为你打开新世界的大门。
|
6天前
|
算法 调度 UED
深入理解操作系统的调度算法
【9月更文挑战第22天】本文通过深入浅出的方式,介绍了操作系统中的核心概念——调度算法。文章首先解释了调度算法的基本定义和重要性,然后详细分析了先来先服务(FCFS)、短作业优先(SJF)以及时间片轮转(RR)三种常见的调度算法。每种算法都配有简单的代码示例,帮助读者更好地理解其工作原理。最后,文章探讨了这些调度算法在现代操作系统中的应用及其优缺点,旨在为读者提供对操作系统调度机制的全面认识。
|
11天前
|
算法 调度 Python
探索操作系统的内核——一个简单的进程调度示例
【9月更文挑战第17天】在这篇文章中,我们将深入探讨操作系统的核心组件之一——进程调度。通过一个简化版的代码示例,我们将了解进程调度的基本概念、目的和实现方式。无论你是初学者还是有一定基础的学习者,这篇文章都将帮助你更好地理解操作系统中进程调度的原理和实践。
|
14天前
|
算法 调度 Python
深入理解操作系统:进程管理与调度
【9月更文挑战第14天】操作系统是计算机系统的核心,负责管理和控制计算机硬件资源,并提供用户和应用程序所需的服务。本文将介绍操作系统中进程管理与调度的基本概念、原理和实现方法,并通过代码示例进行说明。通过阅读本文,读者可以深入了解操作系统的工作原理和机制,提高对计算机系统的理解和掌握能力。