欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java實(shí)現(xiàn)簡(jiǎn)單銀行家算法

 更新時(shí)間:2019年12月26日 11:50:03   作者:SZ996795  
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)簡(jiǎn)單銀行家算法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了java實(shí)現(xiàn)銀行家算法的具體代碼,供大家參考,具體內(nèi)容如下

題目:

初始時(shí),Allocate[i,j]=0,表示初始時(shí)沒有進(jìn)程得到任何資源。假定進(jìn)程對(duì)資源的請(qǐng)求序
列為:

Request(1)[M]=(1,0,0);
Request(2)[M]=(2,1,0);
Request(2)[M]=(2,0,1);
Request(3)[M]=(2,1,1);
Request(4)[M]=(0,0,2);
Request(2)[M]=(1,0,1);
Request(1)[M]=(1,0,1);

請(qǐng)用 Banker 算法判斷每一次資源請(qǐng)求是否接受,如果接受請(qǐng)求,請(qǐng)給出請(qǐng)求接受后的資
源分配狀態(tài),即 Allocate 矩陣、Need 矩陣和 Available 向量。

大致思路:

(1):判斷該進(jìn)程資源請(qǐng)求是否小于Need需求矩陣,小于則進(jìn)第二步
(2):判斷該進(jìn)程資源請(qǐng)求向量是否小于剩余資源向量Available,小于則進(jìn)入第三步
(3):備份下資源狀態(tài)矩陣,假設(shè)接收該需求,求出相應(yīng)的資源狀態(tài)矩陣,需求矩陣,剩余資源向量
(4):判斷接收請(qǐng)求后的狀態(tài)是否是安全狀態(tài)
A:初始該狀態(tài)下的進(jìn)程標(biāo)識(shí)都為false,work為資源剩余向量
B;循環(huán)該狀態(tài)下的進(jìn)程,如果滿足標(biāo)識(shí)為false,并且該進(jìn)程的需求向量小于work 則進(jìn)入C,當(dāng)循環(huán)完畢都沒有滿足條件的進(jìn)入D。
C:work+Allocate(對(duì)應(yīng)進(jìn)程的狀態(tài)),將該進(jìn)程對(duì)應(yīng)的進(jìn)程狀態(tài)標(biāo)識(shí)為true,將B的循環(huán)數(shù)變?yōu)?,從頭開始循環(huán)(進(jìn)入B)
D:循環(huán)遍歷該狀態(tài)下的進(jìn)程標(biāo)識(shí),如果都為true則判斷狀態(tài)安全,否則判斷狀態(tài)不安全
(5):如果狀態(tài)是安全的輸入該狀態(tài)下的各個(gè)矩陣與向量,如果不安全,則利用剛剛備份的資源狀態(tài)矩陣,回滾。

運(yùn)行截圖:

源代碼

package Banker;

public class Banker {
 public static int N = 4;// 線程個(gè)數(shù)
 public static int M = 3;// 資源個(gè)數(shù)
 public static int[] Resource = { 9, 3, 6 };// 資源向量;
 public static int[][] Cliam = { { 3, 2, 2 }, { 6, 1, 3 }, { 3, 1, 4 }, { 4, 2, 2 } };
 public static int[][] Allocate = new int[N][M];
 public static int[][] Need = { { 3, 2, 2 }, { 6, 1, 3 }, { 3, 1, 4 }, { 4, 2, 2 } };
 public static int[] Available = { 9, 3, 6 };
 public int[][] state = new int[N][M];
 

 
 public static void main(String args[]) {

 Banker ban = new Banker();
 //請(qǐng)求序列數(shù)組,包含第幾個(gè)請(qǐng)求,那條進(jìn)程,請(qǐng)求資源向量。
 int[][][] re={{{1},{1,0,0}},{{2},{2,1,0}},{{2},{2,0,1}},{{3},{2,1,1}},{{4},{0,0,2}},{{2},{1,0,1}},{{1},{1,0,1}}};
 for(int j=0;j<re.length;j++){
 /*
 * re[j][1] 請(qǐng)求向量
 * re[j][0][0]-1 第幾個(gè)進(jìn)程
 * j第幾個(gè)請(qǐng)求
 */
 ban.judgeqingqiu(re[j][1], re[j][0][0]-1, j);//輸入第幾條進(jìn)程,請(qǐng)求向向量,第幾個(gè)請(qǐng)求,調(diào)用判斷是否符合要求函數(shù) 
 }
 
 
 }


 //判斷請(qǐng)求是否符合要求
 public void judgeqingqiu(int[] Request, int i,int j) {
 /*judgementrequest(Request, i)調(diào)用函數(shù),判斷該進(jìn)程請(qǐng)求向量是否小于請(qǐng)求矩陣中對(duì)應(yīng)的向量請(qǐng)求資源
 * judgementrequest(Request, i)調(diào)用函數(shù),判斷該進(jìn)程請(qǐng)求向量是否小于剩于資源向量
 */
 if (judgementrequest(Request, i) && judgementrequest(Request, i)) {
 distribute(Request,i);//調(diào)用假設(shè)分配函數(shù),并將分配狀態(tài)copy出來
 //judgementsafe(Allocate)判斷是否是安全狀態(tài)
 if (judgementsafe(Allocate)) {
 
 System.out.println("############");
 System.out.println("第"+(j+1)+"個(gè)請(qǐng)求"+"進(jìn)程"+(i+1)+"請(qǐng)求資源被允許");
 printJuzhen("Allocate", Allocate);
 printJuzhen("Need", Need);
 PrintXianglaing("Available", Available);
 } else {
 System.out.println("############");
 System.out.println("第"+(j+1)+"個(gè)請(qǐng)求"+"進(jìn)程"+(i+1)+"請(qǐng)求資源被拒絕");
 erWeiCopy(Allocate, state);
 }
 } else {
 System.out.println("*****************");
 System.out.println("第"+(j+1)+"個(gè)請(qǐng)求"+"進(jìn)程"+(i+1)+"請(qǐng)求資源被拒絕");
 }
 }

 // 假設(shè)符合,分配資源,記錄下剩余資源
 public void distribute(int[] Request,int i) {

 state = erWeiCopy(state, Allocate);//將資源分配矩陣保留下來,如果不正確方便回滾
 Allocate = addrequest(Allocate, Request, i);//分配后的資源分配矩陣
 Need = reducerequest(Need, Allocate);//分配后的資源需求矩陣
 Available = AvaileReduceRequest(Available, Allocate);//分配后的資源剩余矩陣
 }
 
 // 判斷狀態(tài)安全函數(shù)
 public boolean judgementsafe(int[][] Allocate) {
 int[] work = new int[M];//相當(dāng)于標(biāo)記變量,標(biāo)識(shí)進(jìn)程是否符合,如果符合為true
 work = yiweicopy(work, Available);//將剩余資源響亮copy到work中
 boolean safe = true;//安全狀態(tài),默認(rèn)為true
 Boolean[] finish = { false, false, false, false };//相當(dāng)于標(biāo)記變量,標(biāo)識(shí)進(jìn)程是否符合,如果符合為true,初始值都為false
 //循環(huán)遍歷該狀態(tài)中的進(jìn)程,判斷進(jìn)程的資源需求是否小于剩余資源數(shù)
 for (int j = 0; j < N; j++) {
 //進(jìn)程資源請(qǐng)求是否小于剩余資源work,并且該進(jìn)程標(biāo)識(shí)為false,
 if (judgementsafeWork(Need[j], work) && finish[j] == false) {
  finish[j] = true;//,將該進(jìn)程標(biāo)識(shí)為true,改變work
  for (int h = 0; h < M; h++) {
  work[h] = work[h] + Allocate[j][h];
  }
  j = -1;//,將j=0,再次從頭遍歷查看進(jìn)程
 }
 }
 /*
 * 當(dāng)沒有進(jìn)程滿足資源請(qǐng)求是否小于剩余資源work,并且該進(jìn)程標(biāo)識(shí)為false時(shí)
 * 遍歷狀態(tài)數(shù)組,看是否都為true
 */
 for (int m = 0; m < N; m++) {
 if (finish[m] == false) {
  safe = false;//如果狀態(tài)數(shù)組中有false那么將safe設(shè)置為false
 }
 }
 return safe;
 }

 // 判斷狀態(tài)是否安全時(shí)進(jìn)程資源請(qǐng)求是否小于剩余資源work
 public boolean judgementsafeWork(int[] Request, int[] work) {
 for (int k = 0; k < M; k++) {
// PrintXianglaing("",Request);
 if (Request[k] >work[k]) {
  return false;
 }
 }
 return true;//返回狀態(tài)

 }

 
 // 判斷該進(jìn)程請(qǐng)求向量是否小于請(qǐng)求矩陣中對(duì)應(yīng)的向量請(qǐng)求資源
 public boolean judgementrequest(int[] Request, int i) {
 
 for (int j = 0; j < M; j++) {
 if (Request[j] > Need[i][j]) {
 return false;
 }
 }
 
 return true;
 }

 // 判斷該進(jìn)程請(qǐng)求向量是否小于剩于資源向量
 public boolean judgementAvali(int[] Request) {
 for (int j = 0; j < M; j++) {
 if (Request[j] >Available[j]) {
 return false;
 }
 }
 return true;

 }

 // 假設(shè)分配后修改資源分配矩陣
 public int[][] addrequest(int[][] Allocate, int[] Request, int i) {

 for (int h = 0; h < M; h++) {
 Allocate[i][h] = Allocate[i][h] + Request[h];
 }

 return Allocate;

 }

 // 假設(shè)分配后修改資源的需求矩陣
 public int[][] reducerequest(int[][] Need, int[][] state) {
 for (int j = 0; j < N; j++) {
 for (int h = 0; h < M; h++) {
 Need[j][h] = Cliam[j][h] - state[j][h];
 }
 }
 return Need;
 }

 // 假設(shè)分配后修改資源剩余矩陣
 public int[] AvaileReduceRequest(int[] Available, int[][] Allocate) {
 Available = yiweicopy(Available, Resource);
 for (int j = 0; j < N; j++) {
 for (int h = 0; h < M; h++) {
 Available[h] = Available[h] - Allocate[j][h];
 }
 }
 return Available;
 }
 
 // 二維數(shù)組拷貝
 public int[][] erWeiCopy(int[][] x1, int[][] y1) {
 for (int j = 0; j < N; j++) {
 for (int h = 0; h < M; h++) {
 x1[j][h] = y1[j][h];
 }
 }
 return x1;
 }

 // 一維數(shù)組拷貝
 public int[] yiweicopy(int[] x1, int[] y1) {
 for (int j = 0; j < M; j++) {
 x1[j] = y1[j];
 }
 return x1;
 }

 // 打印向量
 public static void PrintXianglaing(String id, int[] x) {
 System.out.println(id);
 for (int j = 0; j < x.length; j++) {
 System.out.print(x[j] + " ");
 }
 System.out.println("");
 }

 // 打印矩陣
 public static void printJuzhen(String id, int[][] y) {
 System.out.println(id);
 for (int j = 0; j < N; j++) {
 for (int h = 0; h < M; h++) {
 System.out.print(y[j][h] + " ");
 }
 System.out.println();
 }
 }

}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java中生成微信小程序太陽碼的實(shí)現(xiàn)方案

    Java中生成微信小程序太陽碼的實(shí)現(xiàn)方案

    這篇文章主要介紹了Java中生成微信小程序太陽碼的實(shí)現(xiàn)方案,本文講解了如何生成微信小程序太陽碼,通過微信提供的兩種方案都可以實(shí)現(xiàn),在實(shí)際的項(xiàng)目中建議采用第二種方案,需要的朋友可以參考下
    2022-05-05
  • JDK的下載、安裝與部署圖文教程

    JDK的下載、安裝與部署圖文教程

    這篇文章主要為大家詳細(xì)介紹了JDK的下載、安裝與部署圖文教程,感興趣的小伙伴們可以參考一下
    2016-06-06
  • Spring?Boot+微信小程序開發(fā)平臺(tái)保存微信登錄者的個(gè)人信息

    Spring?Boot+微信小程序開發(fā)平臺(tái)保存微信登錄者的個(gè)人信息

    這篇文章主要介紹了Spring?Boot+微信小程序開發(fā)平臺(tái)保存微信登錄者的個(gè)人信息,本文主要介紹?wx.login和wx.getProfile接口,因篇幅所限,不能對(duì)其它接口做詳細(xì)介紹?,有興趣者可以查閱官方文檔
    2022-05-05
  • 關(guān)于mybatis一對(duì)一查詢一對(duì)多查詢遇到的問題

    關(guān)于mybatis一對(duì)一查詢一對(duì)多查詢遇到的問題

    這篇文章主要介紹了關(guān)于mybatis一對(duì)一查詢,一對(duì)多查詢遇到的錯(cuò)誤,接下來是對(duì)文章進(jìn)行操作,要求查詢?nèi)课恼拢㈥P(guān)聯(lián)查詢作者,文章標(biāo)簽,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-05-05
  • SpringCloud?Gateway?DispatcherHandler調(diào)用方法詳細(xì)介紹

    SpringCloud?Gateway?DispatcherHandler調(diào)用方法詳細(xì)介紹

    我們第一個(gè)關(guān)注的類就是DispatcherHandler,這個(gè)類提供的handle()方法,封裝了我們之后所有的handlerMappings,這個(gè)DispatcherHandler有點(diǎn)想SpringMVC的DispatchServlet,里面也是封裝了請(qǐng)求和對(duì)應(yīng)的處理方法的關(guān)系
    2022-10-10
  • string boot 與 自定義interceptor的實(shí)例講解

    string boot 與 自定義interceptor的實(shí)例講解

    下面小編就為大家分享一篇string boot 與 自定義interceptor的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2017-12-12
  • java學(xué)生成績(jī)管理系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn)

    java學(xué)生成績(jī)管理系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn)

    這篇文章主要介紹了java學(xué)生成績(jī)管理系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • 基于RecyclerChart的KLine的繪制Scale詳解

    基于RecyclerChart的KLine的繪制Scale詳解

    這篇文章主要為大家詳細(xì)介紹了基于RecyclerChart實(shí)現(xiàn)KLine繪制Scale的相關(guān)資料,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-03-03
  • redis之基于SpringBoot實(shí)現(xiàn)Redis stream實(shí)時(shí)流事件處理方式

    redis之基于SpringBoot實(shí)現(xiàn)Redis stream實(shí)時(shí)流事件處理方式

    這篇文章主要介紹了redis之基于SpringBoot實(shí)現(xiàn)Redis stream實(shí)時(shí)流事件處理方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • Java程序中方法的用法重載和遞歸

    Java程序中方法的用法重載和遞歸

    Java語言中的“方法”在其他語言當(dāng)中也可能被稱為“函數(shù)”(Function)。對(duì)于一些復(fù)雜的代碼邏輯,如果希望重復(fù)使用這些代碼,并且做到“隨時(shí)任意使用”,那么就可以將這些代碼放在一個(gè)大括號(hào)“{}”當(dāng)中,并且起一個(gè)名字。使用代碼的時(shí)候,直接找到名字調(diào)用即可
    2021-10-10

最新評(píng)論