操作系統高響應比優先模擬演算法

来源:https://www.cnblogs.com/zUotTe0/archive/2018/04/16/8859212.html
-Advertisement-
Play Games

這學期剛開始學習操作系統,收到一個作業,百度關於高響應比優先(HRRN,Highest Response Ratio Next)的CPU進程調度模擬演算法,基本思想:短作業優先調度演算法 + 動態優先權機制;既考慮作業的執行時間也考慮作業的等待時間,綜合了先來先服務(FCFS,First Come Fi ...


  這學期剛開始學習操作系統,收到一個作業,百度關於高響應比優先(HRRN,Highest Response Ratio Next)的CPU進程調度模擬演算法,基本思想:短作業優先調度演算法 + 動態優先權機制;既考慮作業的執行時間也考慮作業的等待時間,綜合了先來先服務(FCFS,First Come First Served)和最短作業優先(SJF,Shortest Job First)兩種演算法的特點。

  之後經過多番揣摩... ...決定界面用命令行算了,反正啥也不會...

  關於響應比:

    RR =  (預計運行時間 + 等待時間) / 預計運行時間 = 1 + 等待時間/預計運行時間;

  響應比高者優先進行調度;

 

  關於要求中的周轉時間、帶權周轉時間、平均周轉時間和平均帶權周轉時間:

    周轉時間 =(作業完成的時間 - 作業提交時間);

    帶權周轉時間 = 作業周轉時間 / 作業運行時間;

    平均周轉時間 = (周轉時間1+周轉時間2+...+周轉時間n)/ n;

    平均帶權周轉時間 = (帶權周轉時間1+帶權周轉時間2+...+帶權周轉時間n)/ n;

 

  開始,用vector存儲提交的作業結構體指針,自己設置一個系統時間,畢竟模擬不可能時間流速一毛一樣,接下來就是毫無技術含量的選擇了,關於測試數據,想了想好難輸,還得自己編,於是用隨機函數產生數據;再在主函數參數中提供一個傳遞生成數據數量的參數。

  說到這裡得說一下,關於java老師(沒錯,java老師)說的關於main()的一些情況:

1 int main(int argc, char** argv){ ////argc為參數個數, argv為接下來傳的參數
2     ...
3     return 0;
4 }

 

比如在命令行中調用該函數,***.exe 100,此時有兩個參數,一個為"***.exe", 另一個就是"100"了,分別在argv[0]和argv[1]中。

  首先是數據生成,用為要求格式,所以要小處理一下,感覺這種方法可以在刷ACM題被題目玄學時使用,一個為標準代碼,一個為自己的代碼,目前未試過:

 1 #include "bits/stdc++.h"
 2 using namespace std;
 3 
 4 int ch_to_int(char* s){
 5     int ans = 0, len = strlen(s);
 6     for(int i = 0; i < len; i++) ans = ans*10 + s[i]-'0';
 7     return ans;
 8 }
 9 int main(int argc, char** argv){
10     int k, N, tj/*0~23*/, ys/*0~59*/, tmp;
11     freopen("test.txt", "w", stdout);
12     srand(time(NULL));   //以系統時間為種子生成真正的隨機數
13     N = k = ch_to_int(argv[1]);
14     while(k--){
15         tmp = (rand() + 24)%24 * 100 + (rand() + 6)%6*10 + (rand() + 10)%10;
16         printf("%04d %d\n", tmp, (rand() + N)%N + 1);
17     }
18     return 0;
19 }

 

  調度演算法:

 1 #include "bits/stdc++.h"
 2 #include "windows.h"
 3 using namespace std;
 4 typedef long long ll; 
 5 
 6 //(所有時間以分鐘為單位存儲,需要時轉化) 
 7 
 8 ll systemTime;    //自定義系統當前時間
 9 
10 struct Task{
11     int Tij; //提交時間 
12     int Ysi; //預計運行時間 
13     ll waitingTime;  //等待時間
14     int id; //作業號
15     
16     ll prior(){
17         return 1 + waitingTime*1.0/Ysi;
18     }
19     
20     Task(int T, int Y){
21         Tij = T;
22         Ysi = Y;
23         waitingTime = 0;
24     }
25     ll aroundTime(){
26         return systemTime - Tij + Ysi;
27     }
28     
29     double priorTime(){
30         return aroundTime()*1.0/Ysi;
31     }
32     void disp(int ord){
33         printf("--調度次序: %d --作業號: %04d --調度時間:%02d%02d --周轉時間: %d min(s) --帶權周轉時間%.2f  ...\n", 
34             ord, id, (systemTime/100 + systemTime/60)%24, systemTime%60, aroundTime(), priorTime());
35     }
36 };
37 
38 int cmp1(const Task* a, const Task* b){
39     return (a->Tij) < (b->Tij);
40 }
41 
42 int main(){
43     vector<Task*> taskArr;    ///以不定長數組存儲作業隊列
44     
45     int Tij, Ysi, order;
46     ll ave_aroundTime = 0;
47     double ave_prior_aroundTime = 0;
48     
49     freopen("test.txt", "r", stdin);
50     system(".\\生成測試數據.exe 1024");    //調用測試數據生成程式
51     
52     while(cin>>Tij>>Ysi) taskArr.push_back(new Task(Tij%100 + Tij/100*60, Ysi));
53     
54     ////按提交時間進行排序並編號 
55     sort(taskArr.begin(), taskArr.end(), cmp1);
56     std::vector<Task*>::iterator pos;
57     for(pos = taskArr.begin(); pos != taskArr.end(); pos++){
58         (*pos)->id = pos - taskArr.begin();
59     }
60     
61     std::vector<Task*>::iterator willRun;  //指向即將運行程式 
62     systemTime = (*taskArr.begin())->Tij;    ///將系統當前時間設置為最早提交的作業時間 
63     order = -1;
64     while(!taskArr.empty()){
65         bool flag = false; ///判定是否有新的程式提交 
66         willRun = taskArr.begin();
67         for(pos = taskArr.begin(); pos != taskArr.end(); pos++){
68             if((*pos)->Tij > systemTime) break;
69             willRun = (*willRun)->prior() < (*pos)->prior() ? pos : willRun;
70             flag = true;
71         }
72         if(!flag){
73             willRun = taskArr.begin();
74             systemTime = (*willRun)->Tij;
75         }
76         
77         (*willRun)->disp(++order);
78         
79         ave_aroundTime += (*willRun)->aroundTime();  //總周轉 
80         ave_prior_aroundTime += (*willRun)->priorTime();  //總帶權周轉 
81         
82         for(pos = taskArr.begin(); pos != taskArr.end(); pos++){  //更新等待時間 
83             if((*pos)->Tij < systemTime){
84                 (*pos)->waitingTime += (*willRun)->Ysi;
85             }
86         }
87 
88         systemTime += (*willRun)->Ysi;  //系統時間增加 
89 
90         taskArr.erase(willRun); //結束則刪除 
91         
92         //Sleep(10);
93     }
94     cout<<ave_aroundTime<<' '<<ave_prior_aroundTime<<endl;
95     printf("\n----平均周轉時間: %.2f --平均帶權周轉時間: %.2f ...\n作業結束..", ave_aroundTime*1.0/order, ave_prior_aroundTime/order);
96 
97     return 0;
98 } 

加油( ̄▽ ̄)"


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • CI中的超級對象就是當前控制器對象,它提供了很多屬性,可以通過var_dump($this)列印所有的超級對象; load可以理解為一個載入器,載入了很多功能,可以理解為當你使用 $this -> load 之後CI自動幫你new了一個loader類的對象實例,然後你就可以調用load裡面封裝的各種 ...
  • 這篇不是為了系統介紹Java的輸入輸出流機制的,僅為個人筆記 作為Java小菜,每次上網搜別人的Java讀寫文件的程式參考,總覺得一頭霧水,為什麼要聲明這麼多類,規則是什麼,全然分からない,所以帶著疑問稍微瞭解了一下; Java中存在兩種輸入輸出模式的類,面向位元組(InputStream&Outpu ...
  • 直接用代碼來說明: ...
  • 前言 最新一直在忙著項目上的事情,很久沒有寫博客了,在這裡對關註我的粉絲們說聲抱歉,後面我可能更多的分享我們在微服務落地的過程中的一些經驗。那麼今天給大家講一下在 .NET Core 2 中引入的全新 DiagnosticSource 事件機制,為什麼說是全新呢? 在以前的 .NET Framewo ...
  • 概述 UWP Community Toolkit Extensions 中有一個為 ListView 提供的擴展 - ListViewExtensions,本篇我們結合代碼詳細講解 ListView Extensions 的實現。 ListViewExtensions 為每一種繼承了 ListVie ...
  • 大家在開發C# winform程式的時候有沒有遇到這種情況。就是在某個代碼的地方想方便的列印一個東西,比如某個值,或者某個錯誤,但是我們並不想用MessageBox,又不想列印到log文件中,只是調試的時候看看。似乎說道這,我們好像都是用MessageBox解決的。那麼今天就說一個小小的技巧,就是在 ...
  • 報錯信息如下: 註:為了部分隱私安全需要,已將有問題文件名替換為filename,系統win2008R2,Microsoft .NET Framework 版本:4.0.30319; ASP.NET 版本:4.7.2623.0 第一開始嘗試過給C:\Windows\Microsoft.NET\Fra ...
  • 一、前言 用虛擬機裝Linux系統時,經常會出現一些問題。比如:從主機到虛擬機之間網路不通;虛擬機中無法聯網;虛擬機中的IP地址不固定。為瞭解決這些問題,我曾花了不少時間。在此,記下填坑方法。 二、環境 系統:Centos7.2 虛擬機軟體:Virtualbox 三、目標 配置一臺擁有固定IP、可以 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...