进程调度算法;先来先服务调度算法、短作业优先调度算法、时间片轮转调度算法「建议收藏」

进程调度算法;先来先服务调度算法、短作业优先调度算法、时间片轮转调度算法「建议收藏」一、实验目的和要求1.了解进程调度算法的特点2.掌握进程调度算法,如先来先服务调度算法(firstcomefirstserved,FCFS)、短作业优先调度算法(shotjobfirst,SJF)、时间片轮转调度算法。二、实验内容设计模拟实现FCFS、SJF、时间片轮转调度算法的C语言程序1.FCFS算法:按照作业/进程进入队列的先后顺序进行挑选,先进入的将先进行…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

一、  实验目的和要求

1.  了解进程调度算法的特点

2.  掌握进程调度算法,如先来先服务调度算法(first come first served,FCFS)、短作业优先调度算法(shotjob first,SJF)、时间片轮转调度算法。

二、    实验内容

设计模拟实现FCFS、SJF、时间片轮转调度算法的C语言程序

1.  FCFS算法:按照作业/进程进入队列的先后顺序进行挑选,先进入的将先进行后续步骤的处理。

2.  SJF算法:以进入系统的作业所要求的CPU运行时间的长短为挑选依据,优先选取预计所需服务时间最短的作业进行调度,可以分别用于高级调度和低级调度。

3.  时间片轮转算法:将所有的就绪进程按先来先服务的原则排成一个队列,每次调度时,把处理机分配给队首进程,并令其执行一个时间片。

 

三、  实验步骤

1.  使用C++语言编译程序。

2.  完成算法代码。

3.  运行程序,算出结果。

四、     实验源程序

代码:

#include <stdio.h>
#include <iostream>
#include <queue>
#include <stack>
#include <set>
#include <string>
#include <cstring>
#include <cmath>
#define MAX 1111

const double Max = 11111.0;

using namespace std;

typedef struct FCFS
{

    int mark;
    string name;
    double arrivetime;
    double servetime;
    double starttime;
    double finishtime;
    double roundtime;
    double daiquantime;

    bool operator< (const FCFS &a)const{

        returnarrivetime > a.arrivetime;

    }

}FCFS;



typedef struct SJF
{

    int mark;
    string name;
    double arrivetime;
    double servetime;
    double starttime;
    double finishtime;
    double roundtime;
    double daiquantime;

    bool operator< (const SJF &a)const{

        returnservetime > a.servetime;

    }

}SJF;



typedef struct RDRN

{

    int mark;

    bool flag =true;

    string name;

    double Count =0.0;
    double arrivetime;
    double servetime;
    double starttime;
    double finishtime;
    double roundtime;
    double daiquantime;
    double running= 0.0;

    bool operator< (const RDRN &a)const{

        returnCount > a.Count;

    }

}RDRN;





void FCFS_arithmetic()
{

    FCFS f[MAX];
    FCFS ff;
    int n;
    double averagedaiquantime = 0.0;

    priority_queue<FCFS> q1;

    printf("请输入作业数(整数)\n");

    scanf("%d",&n);

    printf("请输入n组数据,每组数据包括作业名字(字符串)、作业到达时间(浮点数)、作业服务时间(浮点数)(每组数据的给元素之间用空格隔开!):\n");

    for(int i=0;i<n; i++){
        f[i].mark =i;
        cin>>f[i].name;
        scanf("%lf%lf",&f[i].arrivetime,&f[i].servetime);
        q1.push(f[i]);

    }

    doublestarttime = 0.0;
    ff = q1.top();
    q1.pop();
    f[ff.mark].starttime = ff.arrivetime;
    f[ff.mark].finishtime = f[ff.mark].starttime + ff.servetime;
    f[ff.mark].roundtime = f[ff.mark].finishtime - f[ff.mark].arrivetime;
    f[ff.mark].daiquantime = f[ff.mark].roundtime / f[ff.mark].servetime;
    starttime =f[ff.mark].finishtime;
    printf("先来先服务调度算法的作用时间表:\n\n");
    printf("作业名字 到达时间 服务时间 开始时间 完成时间 周转时间 带权周转时间\n");

   cout<<"  "<<f[ff.mark].name;

printf("%10.2f %8.2f %8.2f %8.2f %8.2f%8.2f\n",f[ff.mark].arrivetime,f[ff.mark].servetime,f[ff.mark].starttime,f[ff.mark].finishtime,f[ff.mark].roundtime,f[ff.mark].daiquantime);

   while(!q1.empty()){

        ff =q1.top();
        q1.pop();
       f[ff.mark].starttime = starttime;
       f[ff.mark].finishtime = f[ff.mark].starttime + ff.servetime;
       f[ff.mark].roundtime = f[ff.mark].finishtime - f[ff.mark].arrivetime;
       f[ff.mark].daiquantime = f[ff.mark].roundtime / f[ff.mark].servetime;
       averagedaiquantime += f[ff.mark].daiquantime;
        starttime =f[ff.mark].finishtime;

       cout<<"  "<<f[ff.mark].name;

printf("%10.2f %8.2f %8.2f %8.2f %8.2f%8.2f\n",f[ff.mark].arrivetime,f[ff.mark].servetime,f[ff.mark].starttime,f[ff.mark].finishtime,f[ff.mark].roundtime,f[ff.mark].daiquantime);

    }

    printf("\n平均代权周转时间:\n");

   printf("%.2f\n",averagedaiquantime/n);

}



void SJF_arithmetic()

{

    SJF f[MAX];
    SJF ff;
    int n;
    double starttime = Max;
    double averagedaiquantime = 0.0;
   priority_queue<SJF> q1;
    printf("请输入作业数(整数)\n");
   scanf("%d",&n);

    printf("请输入n组数据,每组数据包括作业名字(字符串)、作业到达时间(浮点数)、作业服务时间(浮点数)(每组数据的给元素之间用空格隔开!):\n");

    for(int i=0;i<n; i++){
        f[i].mark =i;
       cin>>f[i].name;
       scanf("%lf %lf",&f[i].arrivetime,&f[i].servetime);
       if(f[i].arrivetime < starttime) starttime = f[i].arrivetime;
       q1.push(f[i]);

    }

    printf("短作业优先调度算法的作用时间表:\n\n");

    int cnt = 0;

   while(!q1.empty()){

        SJFtemp[MAX];
        ff =q1.top();
        q1.pop();

       if(f[ff.mark].arrivetime <= starttime){
            for(inti=0; i<cnt; i++) q1.push(temp[i]);
            cnt =0;
           f[ff.mark].starttime = starttime;
           f[ff.mark].finishtime = f[ff.mark].starttime + ff.servetime;
           f[ff.mark].roundtime = f[ff.mark].finishtime - f[ff.mark].arrivetime;
           f[ff.mark].daiquantime = f[ff.mark].roundtime / f[ff.mark].servetime;
           averagedaiquantime += f[ff.mark].daiquantime;
           starttime = f[ff.mark].finishtime;

        }

        elsetemp[cnt++] = ff;

    }

    printf("作业名字 到达时间 服务时间 开始时间 完成时间 周转时间 带权周转时间\n");

    for(int i=0;i<n; i++){

       cout<<"  "<<f[i].name;

       printf("%10.2f %8.2f %8.2f %8.2f %8.2f%8.2f\n",f[i].arrivetime,f[i].servetime,f[i].starttime,f[i].finishtime,f[i].roundtime,f[i].daiquantime);

    }

    printf("\n平均代权周转时间:\n");

   printf("%.2f\n",averagedaiquantime/n);

}



void RDRN_arithmetic()
{

    double timeslice;
    RDRN f[MAX];
    RDRN temp[MAX];
    int cnt = 0;
    RDRN ff;
    int n;
    double averagedaiquantime = 0.0;
   priority_queue<RDRN> q1;

    printf("请输入作业数和时间片长度(作业数为整数,时间片长度可为浮点数,中间用空格隔开!):\n");

    scanf("%d%lf",&n,&timeslice);

    int tot = n;

    printf("请输入n组数据,每组数据包括作业名字(字符串)、作业到达时间(浮点数)、作业服务时间(浮点数)(每组数据的给元素之间用空格隔开!):\n");

    for(int i=0;i<n; i++){

        f[i].mark =i;
       cin>>f[i].name;
       scanf("%lf %lf",&f[i].arrivetime,&f[i].servetime);
        f[i].Count= f[i].arrivetime;
       q1.push(f[i]);

    }

    double clock =q1.top().arrivetime;

    int t = 0;

    while(t != n){

        ff =q1.top();

       if(f[ff.mark].arrivetime <= clock && tot-- > 0){
           q1.pop();
           if(f[ff.mark].flag){
               f[ff.mark].starttime = clock;
               f[ff.mark].flag = false;
            }



           if(f[ff.mark].running != f[ff.mark].servetime){

               double newtime = f[ff.mark].servetime - f[ff.mark].running;
               if(newtime >= timeslice){
                   clock += timeslice;
                   f[ff.mark].running += timeslice;
                   f[ff.mark].Count += timeslice;
                }

               else{
                   clock += newtime;
                   f[ff.mark].running += newtime;
                   f[ff.mark].Count += newtime;
                }

               if(f[ff.mark].running != f[ff.mark].servetime) temp[cnt++] = f[ff.mark];

            }



           if(f[ff.mark].running == f[ff.mark].servetime){
               t++;
               f[ff.mark].finishtime = clock;
               f[ff.mark].roundtime = f[ff.mark].finishtime - f[ff.mark].arrivetime;
               f[ff.mark].daiquantime = f[ff.mark].roundtime / f[ff.mark].servetime;
               averagedaiquantime += f[ff.mark].daiquantime;
            }

        }



        else{
            for(inti=0; i<cnt; i++) q1.push(temp[i]);
            cnt =0;
            tot =q1.size();
        }

    }



    printf("时间轮转调度算法的作用时间表:\n\n");

    printf("作业名字 到达时间 服务时间 开始时间 完成时间 周转时间 带权周转时间\n");

    for(int i=0;i<n; i++){

       cout<<"  "<<f[i].name;

printf("%10.2f %8.2f %8.2f %8.2f %8.2f %8.2f\n",f[i].arrivetime,f[i].servetime,f[i].starttime,f[i].finishtime,f[i].roundtime,f[i].daiquantime);

    }

    printf("\n平均代权周转时间:\n");

   printf("%.2f\n",averagedaiquantime/n);

}



int main()

{

   printf("********************************************************欢迎您!***********************************************************\n");

    int ca = 0;

    do{
       printf("\n请选择调度算法或结束程序:\n");
       printf("0、结束程序\n1、先来先服务\n2、短作业优先\n3、时间片轮转\n");
       scanf("%d",&ca);
        if(ca == 1)FCFS_arithmetic();
        if(ca == 2)SJF_arithmetic();
        if(ca == 3) RDRN_arithmetic();
    }while(ca);

    return 0;

}

五、  实验结果

先来先服务调度算法:

进程调度算法;先来先服务调度算法、短作业优先调度算法、时间片轮转调度算法「建议收藏」

短作业优先调度算法:

 进程调度算法;先来先服务调度算法、短作业优先调度算法、时间片轮转调度算法「建议收藏」

时间片轮转调度算法:

 进程调度算法;先来先服务调度算法、短作业优先调度算法、时间片轮转调度算法「建议收藏」

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/187796.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • modelsim教程

    modelsim教程TheTutorialof Modelsim小狼@http://blog.csdn.net/xiaolangyangyang一、建立库vlibwork(库名)二、映射库到物理目录vmapwork(映射的逻辑名称)work(存放的物理地址)三、编译源代码vlog../src/MUX_4_8.vvlog../src/MU

    2022年10月22日
    0
  • Django(59)验证和授权[通俗易懂]

    Django(59)验证和授权[通俗易懂]验证和授权概述Django有一个内置的授权系统。他用来处理用户、分组、权限以及基于cookie的会话系统。Django的授权系统包括验证和授权两个部分。验证是验证这个用户是否是他声称的人(比如用户名

    2022年8月7日
    1
  • 用js来实现那些数据结构11(字典)

    我们这篇文章来说说Map这种数据结构如何用js来实现,其实它和集合(Set)极为类似,只不过Map是【键,值】的形式存储元素,通过键来查询值,Map用于保存具有映射关系的数据,Map里保存着两组数据:

    2022年3月25日
    62
  • 我的手机软件

    我的手机软件总结一下现在我装的软件,这些我都有安装版,兄弟们可以复用:)我的手机:Nokia6680操作系统:Symbian60Ⅲ目前手机上装的:6630EditableQuickOffice2.sisoffice套件,实际用的很少。6681字典字库.SIS字典,有用。ACM超级来电管家来电管家,当然有用啦,防火墙,自动短信回复…

    2022年7月11日
    14
  • UFT自动化测试

    UFT自动化测试自动化测试静态自动化:代码检测,类似于编译工具的编译系统动态自动化:基于浏览器和DOM对象的自动化:selemnium,Selenium测试直接运行在浏览器中,就像真正的用户在操作一样。支持的浏览器包括IE(7、8、9)、MozillaFirefox、MozillaSuite等。这个工具的主要功能包括:测试与浏览器的兼容性–测试你的应用程序看是否能够很好得工作在不同浏览器和操作系统之上。测试系统功能–创建回归测试检验软件功能和用户需求。支持自动录制动作和自动生成Net、J…

    2022年5月28日
    61
  • 浏览器dns缓存清理_怎么清除ip地址缓存

    浏览器dns缓存清理_怎么清除ip地址缓存有dns的地方,就有缓存。浏览器、操作系统、LocalDNS、根域名服务器,它们都会对DNS结果做一定程度的缓存。本文总结一些常见的浏览器和操作系统的DNS缓存时间浏览器先查询自己的缓存,查不到,

    2022年8月6日
    39

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号