銀行家算法核心
成都創新互聯專注骨干網絡服務器租用十年,服務更有保障!服務器租用,德陽機房托管 成都服務器租用,成都服務器托管,骨干網絡帶寬,享受低延遲,高速訪問。靈活、實現低成本的共享或公網數據中心高速帶寬的專屬高性能服務器。先尋找滿足系統當前剩余的資源量(avaliable )>=進程運行所需的資源數的進程(need),再假設這個進程安全校驗是成功的,當這個進程運行完畢后,釋放資源后,現在系統當前剩余的資源(avaliable)=avaliable+該線程之前已分配的資源(allocation) ,將該節點進程設為處理時忽略進程,再以上條件為前提進行安全校驗。
安全校驗:一個進程獲得資源后,運行完畢,釋放之前分配的資源,其他的線程可以繼續運行,而不會造成死鎖。
這樣就會產生回溯。
滿足條件:是否存在一個進程運行所需的資源數<=當前系統剩余的資源數。
查找操作:先判斷回溯的步長(層數)是否等于節點的個數,如果等于說明已經找到了正確路徑,返回真給上一層,如果不滿足,則看一下此層是否存在滿足條件的節點,如果存在,這一該節點為回溯點開始查找操作。如果都不存在,說明上一層的回溯點不是我們要找的節點,返回假給上一層,并回溯回到上一層節點,將忽略標記清楚,換另一個滿足條件的節點繼續在進行查找操作。
先以一個滿足條件的節點進行忽略標記(下一次查找時可忽略此節點),回溯的步長加一,再進行查找操作(下一層)。
import java.util.Arrays; public class BanksTest { // 用于存儲預操作后的資源變化 static int[] new_Avaliable = null; // 用于存儲預操作的完成度 static boolean[] new_finish = null; // 用于保存最終的進程執行順序,初始化為非法進程-1 static int right[] = { -1, -1, -1, -1, -1 }; public static void main(String[] args) { // 大需求量 int[][] max = { { 7, 5, 3 }, { 3, 2, 2 }, { 9, 0, 2 }, { 2, 2, 2 }, { 4, 3, 3 } }; // 當前系統可用資源量 int[] avaliable = { 3, 3, 2 }; // 每個進程運行還需資源量 int[][] need = new int[5][3]; // 每個進程已分配的資源量 int[][] allocation = { { 0, 1, 0 }, { 2, 0, 0 }, { 3, 0, 2 }, { 2, 1, 1 }, { 0, 0, 2 } }; // 用于第一深度預判的初始化 boolean finish[] = { false, false, false, false, false }; // 獲取每個進程運行時還需的資源量 for (int i = 0; i < max.length; i++) { for (int j = 0; j < max[i].length; j++) { need[i][j] = max[i][j] - allocation [i][j]; } } // 創建遞歸深度 int deep = 0; // 調用回溯遞歸算法 deepCheck(avaliable, allocation, need, finish, deep, right); int i = 0; // 查看最終的安全序列的值,看是否存在初始的非法進程,如果存在,則說明該案例不存在安全的進程執行順序 for (; i < right.length; i++) { if (right[i] == -1) { break; } } if (i < right.length) { System.out.println("該案例不存在安全的進程執行順序"); return; } // 打印安全的執行順序 for (int j = 0; j < right.length; j++) { System.out.println(right[j]); } } // 完全遞歸回溯查找安全順序 public static boolean deepCheck(int[] avaliable, int[][] allocation, int[][] need, boolean finish[], int deep, int right[]) { int j = 0; boolean flog = false; // 如果深度為進程的個數數說明已經查找到頭了,說明上一深度的進程是安全節點。因為上一深度的進程滿足了當前資源數大于或等于該進程運行所需的資源數,且為安全序列中最后一個節點。 if (deep == need.length) { return true; } // 遍歷所有節點進程開始查找,直到找到安全校驗成功的的節點進程 for (int i = 0; i < need.length; i++) { // 對于未被標記的進行校驗,已被標記的為已被列為安全節點所以無需再進行校驗 if (!finish[i]) { // 判斷當前的節點進程的剩余的資源量,是否滿足運行所需的資源量 for (j = 0; j < avaliable.length; j++) { // 不滿足 if (need[i][j] > avaliable[j]) { break; } } // 不滿足則處理下一個節點進程 if (j < avaliable.length) { continue; } else { // 滿足情況 // 復制會被修改的前提條件,已便于當前進程校驗不成功時,可以恢復前提條件,開始下一個節點進程的校驗 new_Avaliable = Arrays.copyOf(avaliable, avaliable.length); new_finish = Arrays.copyOf(finish, finish.length); // 假設當前節點進程是可以校驗成功的節點進程,修改該進程運行完畢后釋放之前分配的進程。 for (j = 0; j < new_Avaliable.length; j++) { new_Avaliable[j] += allocation[i][j]; } // 假設標記當前為校驗成功的安全節點進程,下一深度查找時會忽略此進程。 new_finish[i] = true; // 增加深度 deep++; // 以上假設為前提,進行下一深度的安全校驗判斷其他所剩余進程是否可以繼續運行,而不造成死鎖。 flog = deepCheck(new_Avaliable, allocation, need, new_finish, deep, right); // 如果進行安全校驗后為真,說明當前進程是我們要找的進程 if (flog) { // 保存到最終進程執行序列的數組中 right[--deep] = i; break; } } } } // 安全校驗成功 if (flog) { return true; } else { // 安全校驗失敗 // 清楚之前的假設標記 new_finish[right[--deep]] = false; return false; } } }
另外有需要云服務器可以了解下創新互聯建站m.newbst.com,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
新聞標題:使用java實現銀行家算法-創新互聯
分享路徑:http://m.newbst.com/article8/dpehip.html
成都網站建設公司_創新互聯,為您提供網站設計、網站排名、軟件開發、網站制作、網站導航、用戶體驗
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯