磁盘调度可视化实现-创新互联

如需源码请关注并私信博主哦(本文实现了先来先服务算法(FCFS),最短寻道时间优先算法(SSTF),扫描算法(SCAN),循环扫描算法(CSCAN))

成都创新互联-专业网站定制、快速模板网站建设、高性价比汝南网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式汝南网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖汝南地区。费用合理售后完善,10年实体公司更值得信赖。

【设计目的】

掌握文件的存取方法;掌握文件的逻辑结构和物理结构;掌握存储空间的分配和回收;掌握磁盘管理与调度。

【设计内容】

用程序模拟磁盘的调度过程,并计算各磁盘调度算法包括先来先服务算法、最短寻道时间优先算法、扫描算法和循环扫描算法的平均寻道长度。

【设计步骤】

  1. 分析常用的磁盘调度算法,熟悉其基本原理。

(篇幅有限,以SSTF算法为例)

  1. 用提供的GUI界面自行设定起始扫描磁道号及大磁道号数,程序根据设定值产生磁道号进行模拟。
  2. 编写程序实现磁盘调度算法,并显示该算法寻道顺序并计算出寻道总数和平均寻道数;
static int[] a;
static Integer direction;
static String master;
static int first;


static int[] SSTF(int a[],int index){
   if (a[index]==a[0]){
      //不做变化

   }else if (a[index]==a[a.length-1]){
      //数组对调
      for (int start = 0, end = a.length - 1; start< end; start++, end--) {
         int temp = a[end];
         a[end] = a[start];
         a[start] = temp;
      }

   }else {
      //int c[a.length-1];
      int []c = Arrays.copyOf(a,a.length);      //数组复制,不能直接复制!!!
      a[0] = c[index];
      int left=index-1,right=index+1;       //左右指针

      for (int i = 1; i< a.length;i++) {

         if ((c[index] - c[left]) >(c[right] - c[index])) {            //index右移一位

            if (c[right]< c[c.length - 1]) {

               a[i] = c[right];
               index = right;
               right++;
            } else {
               a[i] = c[c.length - 1];                //到右端点又变成SCAN
               for (int k = 1; c[left] >c[0]; k++) {
                  a[i + k] = c[left];
                  left--;
               }
               break;
            }

         } else {
            if (c[left] >c[0]) {
               a[i] = c[left];
               index = left;
               left--;
            }else{
                  a[i] = c[0];                //到左端点又变成SCAN
                  for (int k = 1; c[right]< c[c.length - 1]; k++) {
                     a[i + k] = c[right];
                     right++;
                  }
                  break;
               }
            }
         }

      }
   return a;
}

  1. 测试并运行程序,给出运行界面。

以SSTF为例:

磁道访问序列: 55 58 39 18 90 160 150 38 184

预期输出:100  90  58  55  39  38  18  150  160  184

测试结果

主界面

运行效果 

你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧


分享文章:磁盘调度可视化实现-创新互联
转载来于:http://pwwzsj.com/article/psieh.html