亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C#實現(xiàn)銀行家算法

 更新時間:2021年05月10日 08:46:06   作者:Zoe_hedgehog  
這篇文章主要為大家詳細介紹了C#實現(xiàn)銀行家算法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

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

1.死鎖

死鎖,顧名思義,是一種鎖住不可自行解開的死局。

在操作系統(tǒng)中,“死鎖”用于描述資源分配時,進程互相搶占資源,又因為需求的資源被別的進程搶占,只好互相等待,以至于等待循環(huán)中的所有進程均無法正常運行的情況。

死鎖形成需要四個條件,這四個條件缺少一個,就不會形成死鎖。

死鎖的四個條件

1)互斥條件

    即對于某資源在一段時間內(nèi)僅允許一個進程占有使用。

2)占有且等待條件/請求和保持條件

    在進程已經(jīng)占有一個或多個資源的情況下,若它仍申請新的資源,在等待獲得新的資源時,進程仍會繼續(xù)占有舊有資源,不會主動釋放。

3)不可搶占條件

    直到占有該資源的進程使用完畢之前,其他任何進程均不應該強行搶占該資源。

4)循環(huán)等待條件

    若干個進程之間形成了一個等待循環(huán)。

2.安全狀態(tài)

若針對目前資源分配情況,系統(tǒng)可以找到某種次序為進程分配資源,使得所有進程能夠依次運行成功,則稱系統(tǒng)此時的分配狀態(tài)是安全的,分配資源的次序稱為“安全序列”。

安全狀態(tài)時系統(tǒng)中無死鎖,所以所有避免死鎖的算法都盡可能地使系統(tǒng)進入安全狀態(tài)。

值得注意的是,即使是安全狀態(tài)下的系統(tǒng),如果資源分配不當,仍然可以使系統(tǒng)變?yōu)椴话踩珷顟B(tài)。

3.銀行家算法

1)設(shè)計思想

在系統(tǒng)中,進程發(fā)起一項資源分配請求,由系統(tǒng)檢查是否可以滿足該分配請求,若可以,應暫時滿足該請求,并查看此時系統(tǒng)是否仍是安全狀態(tài)。

2)程序流程圖

可以分為三個功能模塊,第一個模塊檢查需求是否可以被滿足,第二個模塊檢查系統(tǒng)是否安全,第三個模塊是主程序,通過調(diào)用前兩個模塊實現(xiàn)資源分配或請求駁回。

3)數(shù)據(jù)結(jié)構(gòu)

設(shè)有m種資源,n個進程。

int[] Available[m] 系統(tǒng)內(nèi)可用資源

int[,] Max[n,m] 進程對每種資源的最大需求

int[,] Allocation[n,m] 已分配給各個進程的資源

int[,] Need[n,m] 目前各個進程對各個資源的需求數(shù)

[顯然有Need=Max-Allocation]

int[,] Require[m] 對于各種資源的請求函數(shù)

bool[] Finish[n] 進程是否可以成功運行的標志

int[] Work[m] 用于分配資源的向量
[定義:Work=Available-Require]

4)窗體設(shè)計

5)窗體代碼

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
 
namespace bank
{
    public partial class Form1 : Form
    {
        public int n = 1;//進程數(shù)目
        public int m = 1;//資源分類數(shù)
        int[,] Allocation;
        int[,] Max;
        int[] Available;
        int[,] Need;
        int[] Require;
        string order;//輸出安全序列
 
        public Form1()
        {
            InitializeComponent();
 
        }
 
        private void button1_Click(object sender, EventArgs e)
        {
            n = Convert.ToInt32( tb_proNum.Text);
            m = Convert.ToInt32(tb_resouseClass.Text);
        }
 
        private void button2_Click(object sender, EventArgs e)
        {
            if (rb_allocation.Checked)
            {
                tb_output.Text  += "Allocation矩陣\r\n";
                string[] str = tb_datainput.Text.Split(' ');
 
                 Allocation = new int[n, m];
                for (int i = 0; i < n; i++)
                {
                    tb_output.Text+="\r\n";
                   string[] temp= str[i].Split(',');
                   for (int j = 0; j < m; j++)
                   {
                       Allocation[i, j] = Convert.ToInt32(temp[j]);
                       tb_output.Text += " " + Allocation[i, j];
                   }
                }
                
            }
            else if (rb_available.Checked)
            {
                tb_output.Text += "\r\nAvailable向量\r\n";
                string[] str = tb_datainput.Text.Split(',');
                Available = new int[m];
                for (int i = 0; i < m; i++)
                {
                    Available[i] = Convert.ToInt32(str[i]);
                    tb_output.Text += " " + Available[i];
                }        
            }
            else//輸入max矩陣
            {
                tb_output.Text += "\r\nMax矩陣\r\n";
                string[] str = tb_datainput.Text.Split(' ');
                Max = new int[n, m];
                
                for (int i = 0; i < n; i++)
                {
                    tb_output.Text+="\r\n";
                    string[] temp = str[i].Split(',');
                    for (int j = 0; j < m; j++)
                    {
                        Max[i, j] = Convert.ToInt32(temp[j]);
                        tb_output.Text += " " + Max[i, j];
                    }
                }
            }
        }
 
        private void button3_Click(object sender, EventArgs e)
        {
            int PID = 0;
            bool[] finish = new bool[n];
            for (int i = 0; i < n; i++)
            {
                finish[i] = false;
            }
            if (tb_pid.Text == "")
                ;
            else
                PID = Convert.ToInt32(tb_pid.Text) ;
 
 
            int bigger_1 = 0;
            int bigger_2 = 0;
            ///計算Need矩陣///
            Need = new int[n, m];
            tb_output.Text += "\r\nNeed矩陣\r\n";
            for (int i = 0; i < n; i++)
            {
                tb_output.Text += "\r\n";
                for (int j = 0; j < m; j++)
                {
                    Need[i, j] = Max[i, j] - Allocation[i, j];
                    tb_output.Text += " " + Need[i, j];
                }
            }
            ///輸入Require///
            if (tb_require.Text == "")
            {
                Require = new int[m];
                for (int i = 0; i < m; i++)
                { Require[i] = 0; }
                PID = 0;
                tb_output.Text += "\r\n檢測當前狀態(tài)是否安全中…\r\n";
                if (CheckSecure(Available, finish, Need, Allocation))
                {
                    tb_output.Text += "系統(tǒng)目前安全"+"安全序列"+order;
                }
                else
                {
                    tb_output.Text += "系統(tǒng)目前不安全";
 
                }
            }
            else
            {
                string[] str = tb_require.Text.Split(',');
                Require = new int[m];
                for (int i = 0; i < m; i++)
                {
                    Require[i] = Convert.ToInt32(str[i]);
                    if (Require[i] > Need[PID, i])
                        bigger_1++;
                    if (Require[i] > Available[i])
                        bigger_2++;
 
                }
 
                ///檢查///
                if (bigger_1 != 0)
                {
                    tb_output.Text += "\r\n錯誤:進程申請的資源多于說明的最大量,系統(tǒng)無法滿足\r\n";
                }
                else if (bigger_2 != 0)
                {
                    tb_output.Text += "\r\n進程" + tb_pid.Text + "暫時阻塞\r\n";
                }
                else
                {
                    int[] temp_available = Available;
                    int[,] temp_allocation = Allocation;
                    int[,] temp_need = Need;
 
                    for (int j = 0; j < m; j++)
                    {
                        temp_available[j] -= Require[j];
                        temp_allocation[PID, j] += Require[j];
                        temp_need[PID, j] -= Require[j];
 
                    }
 
                    if (CheckSecure(temp_available, finish, temp_need, temp_allocation))
                    {
                        Available = temp_available;
                        Allocation = temp_allocation;
                        Need = temp_need;
                        tb_output.Text += "\r\n系統(tǒng)處于安全狀態(tài),且已經(jīng)分配完畢\r\n"+"安全序列"+order ;
 
                    }
                    else
                    { tb_output.Text += "\r\n該請求將導致系統(tǒng)處于不安全狀態(tài),已經(jīng)撤銷分配\r\n"; }
 
                }
            }
        }
///檢查安全狀態(tài)///
 public bool CheckSecure(int[] work,bool[] finish,int[,] temp_need,int[,] temp_allocation)
        {
            int num = 0;//need[i]<=work[i]的個數(shù)
            order ="";
            int[] wor = work;
            bool[] finis = finish;
            int[,] temp_nee = temp_need;
            int[,] temp_allocatio = temp_allocation;
int K=0;
while (K < 10)
{
    for (int i = 0; i < n; i++)
    {
        if (!finis[i])
        {
            for (int j = 0; j < m; j++)
            {
                if (temp_nee[i, j] <= wor[j])
                    num++;
 
            }
            if (num == m)
            {
                for (int j = 0; j < m; j++)
                {
                    wor[j] += temp_allocatio[i, j];
                }
                finis[i] = true;
                order += i;
                
                num = 0;
 
            }
            else num = 0;
 
 
        }
        else
            if (checkFinish(finis))
                return true;
 
    }
    K++;
} 
               
 
            if (checkFinish(finis))
            
                return true;
            
            else
                return false;
            }
 
            public bool checkFinish(bool[] f)
            {int num=0;
                foreach (bool k in f)
                {
                    if (k)
                        num++;
                    
                }
                if (num == f.Length)
                    return true;
                else return false;
            } 
    }
}

計算效果如下:

3.總結(jié)

實現(xiàn)功能

允許輸入數(shù)據(jù)(只輸入Available,Max,Allocation即可,Need可以自動計算,矩陣同一行元素之間用“,”隔開,換行時用空格隔開)

使用銀行家算法進行安全檢查(若未提出請求,則應使進程號與Require后面的textbox內(nèi)容為空,點擊“提出請求”按鈕即可檢查當前系統(tǒng)安全狀態(tài))

輸出狀態(tài)結(jié)果

輸出安全序列(注:輸出的是進程號,默認序號從0開始)

不足之處

未寫出完整的約束

不能輸出分配成功后的系統(tǒng)狀態(tài)
交互不夠人性化,例如沒有在輸出文本框中加入滾動條,不方便使用者查看結(jié)果

問題

例子中經(jīng)過程序計算后的need矩陣中出現(xiàn)了負數(shù),不知道是為什么,正在排查錯誤。

關(guān)鍵點

——向量比較:銀行家算法中的向量大小比較與數(shù)學中的向量大小比較(范數(shù)比較)不同,只有向量a中的所有分量均大于向量b,才可以稱為向量a大于向量b。向量比較主要用在檢查Require是否合法,本例中使用for循環(huán)對于兩向量的各個分量進行比較,設(shè)置一個初始值為0的信號變量,若任一分量小于對應分量,則將信號變量++,循環(huán)結(jié)束后只需要檢查信號變量是否為0即可知道是否前者大于后者。
——矩陣輸入:使用split方法,將字符串按照給定符號(char,char[])分隔開,并賦給一個給定大小的數(shù)組,在本例中使用逗號和空格分開了不同列不同行的元素,定義全局變量m與n,在給數(shù)組賦值前需要使用mn初始化數(shù)組大小。

——使用臨時變量代替真實變量,方便恢復變量數(shù)值。因為銀行家算法中,若資源分配后系統(tǒng)不安全,要求系統(tǒng)必須撤銷所有分配,所以使用臨時變量可以避免大量的恢復運算,即使經(jīng)過檢查后,系統(tǒng)為安全狀態(tài),也只需要將臨時變量的值賦給真實變量即可。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • c# 通過WinAPI播放PCM聲音

    c# 通過WinAPI播放PCM聲音

    這篇文章主要介紹了c# 通過WinAPI播放PCM聲音的方法,幫助大家更好的理解和使用c#編程語言,感興趣的朋友可以了解下
    2020-12-12
  • C#類中的屬性使用總結(jié)(詳解類的屬性)

    C#類中的屬性使用總結(jié)(詳解類的屬性)

    屬性是一種類的成員,它的實現(xiàn)類似函數(shù),訪問類似字段。它的作用是提供一種靈活和安全的機制來訪問,修改私有字段。所以屬性必須依賴于字段
    2014-03-03
  • .Net筆記:System.IO之Stream的使用詳解

    .Net筆記:System.IO之Stream的使用詳解

    本篇文章是對.Net中System.IO之Stream的使用進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • C#中this用法系列(二) 通過this修飾符為原始類型擴展方法

    C#中this用法系列(二) 通過this修飾符為原始類型擴展方法

    定義一個靜態(tài)類,類中定義靜態(tài)方法,方法中參數(shù)類型前邊加上this修飾符,即可實現(xiàn)對參數(shù)類型的方法擴展,下面通過實例代碼給大家介紹下,需要的朋友參考下吧
    2016-12-12
  • C#中使用Override和New關(guān)鍵字進行版本控制

    C#中使用Override和New關(guān)鍵字進行版本控制

    在?C#?中,override?和?new?關(guān)鍵字用于控制類之間的成員方法的隱藏和重寫,理解它們之間的差異和使用場景對于設(shè)計靈活且易于維護的代碼至關(guān)重要,在這篇博客中,我們將詳細探討這兩個關(guān)鍵字的用法,并通過示例來說明它們的實際應用,需要的朋友可以參考下
    2024-10-10
  • C#漢字轉(zhuǎn)換拼音技術(shù)詳解(高性能)

    C#漢字轉(zhuǎn)換拼音技術(shù)詳解(高性能)

    通過網(wǎng)上漢字轉(zhuǎn)換成拼音的代碼,經(jīng)過本人優(yōu)化,性能將更加優(yōu)異
    2012-11-11
  • c#系列 list詳情

    c#系列 list詳情

    這篇文章主要介紹了c#系列 list,list 本質(zhì)是一個數(shù)組,。就跟我們操作系統(tǒng)一樣,提前申請內(nèi)存大小。所以我們程序一般都有一個申請內(nèi)存,實際使用內(nèi)存,內(nèi)存碎片這幾個概念,下面?zhèn)z看文章詳細內(nèi)容吧
    2021-10-10
  • C#獲取真實IP地址(IP轉(zhuǎn)為長整形、判斷是否內(nèi)網(wǎng)IP的方法)

    C#獲取真實IP地址(IP轉(zhuǎn)為長整形、判斷是否內(nèi)網(wǎng)IP的方法)

    這篇文章主要介紹了C#獲取真實IP地址的實現(xiàn)代碼,包含把IP轉(zhuǎn)為長整形、判斷是否是私網(wǎng)、內(nèi)網(wǎng)IP的方法,需要的朋友可以參考下
    2014-08-08
  • C# IEnumerable和IEnumerator接口淺析

    C# IEnumerable和IEnumerator接口淺析

    本文主要介紹了C#中IEnumerable和IEnumerator接口的相關(guān)知識,具有很好的參考價值,下面跟著小編一起來看下吧
    2017-02-02
  • C#多線程之線程綁定ThreadLocal類

    C#多線程之線程綁定ThreadLocal類

    這篇文章介紹了C#多線程之線程綁定ThreadLocal類的用法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06

最新評論