亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 算法2.txt

?? 還是一個銀行家算法,不過這一個要更加深奧這個可厲害啊
?? TXT
字號:
   摘要:銀行家算法實現 
 
 
特別申明:轉載一位大哥的程序
一.算法介紹:
**數據結構:
1.可利用資源向量Available
2.最大需求矩陣Max
3.分配矩陣Allocation
4.需求矩陣Need
  **功能介紹:
模擬實現Dijkstra的銀行家算法以避免死鎖的出現.分兩部分組成:
第一部分:銀行家算法(掃描)
1.如果Request<=Need,則轉向2;否則,出錯
2.如果Request<=Available,則轉向3,否則等待
3.系統試探分配請求的資源給進程
4.系統執行安全性算法
第二部分:安全性算法
1.設置兩個向量
(1).工作向量:Work=Available(表示系統可提供給進程繼續運行所需要的各類資源數目)
(2).Finish:表示系統是否有足夠資源分配給進程(True:有;False:沒有).初始化為False
2.若Finish[i]=False&&Need<=Work,則執行3;否則執行4(I為資源類別)
3.進程P獲得第i類資源,則順利執行直至完成!并釋放資源:
Work=Work+Allocation;
Finish[i]=true;
轉2
4.  若所有進程的Finish[i]=true,則表示系統安全;否則,不安全!

二.原代碼及注釋:
#include<iostream.h>
#include<fstream.h>
#include<stdlib.h>
#include "windows.h"
#define MAX_PROCESS 32              //最大進程數
#define MAX_COURCE 64              //最大資源類別

int MAX_FACT_PROCESS;              //實際總進程數
int MAX_FACT_COURCE;               //實際資源類別數
int Available[MAX_COURCE];                 //可利用資源向量
int Max[MAX_PROCESS][MAX_COURCE];          //最大需求矩陣
int Allocation[MAX_PROCESS][MAX_COURCE];   //分配矩陣
int Need[MAX_PROCESS][MAX_COURCE];         //需求矩陣

int Request_PROCESS;                       //發出請求的進程
int Request_COURCE;                        //被請求資源類別
int Request_COURCE_NEMBER;                 //請求資源數

struct COMP{
int value;
int num;
int next;
};
int flag=0;
void Read_Initiate(void){                             //讀入初始化文檔
ifstream infile("Initiate.txt");
   if(!infile){
cout<<"不能打開輸入文件:"<<"Initiate.txt"<<'\n';
exit(1);
}
cout<<"開始讀入初始化文檔"<<'\n';
int ch;
int Array[MAX_PROCESS*MAX_COURCE*2];
int num=0;
while(infile>>ch)
    Array[num++]=ch;
num=0;
   MAX_FACT_COURCE=Array[num++];
   for(int j=0;j<MAX_FACT_COURCE;j++)
Available[j]=Array[num++];
   MAX_FACT_PROCESS=Array[num++];
for(int i=0;i<MAX_FACT_PROCESS;i++){
for(int j=0;j<MAX_FACT_COURCE;j++)
Max[i][j]=Array[num++];
}
infile.close();
}

void Write_Initiate(void){                                  //寫入初始化文檔(分配資源
ofstream outfile("Initiate.txt");
if(!outfile){
cout<<"不能打開初始化文檔:"<<'\n';
exit(1);
}
int Array[MAX_PROCESS*MAX_COURCE*2];
int num=0;
Array[num++]=MAX_FACT_COURCE;
   for(int i=0;i<MAX_FACT_COURCE;i++)
Array[num++]=Available[i];
Array[num++]=MAX_FACT_PROCESS;
for(i=0;i<MAX_FACT_PROCESS;i++)
for(int j=0;j<MAX_FACT_COURCE;j++)
Array[num++]=Max[i][j];

num=0;
outfile<<Array[num++]<<" ";
for(i=0;i<MAX_FACT_COURCE;i++)
outfile<<Array[num++]<<" ";
outfile<<'\n'<<Array[num++]<<endl;
for(i=0;i<MAX_FACT_PROCESS;i++){
for(int j=0;j<MAX_FACT_COURCE;j++)
outfile<<Array[num++]<<" ";
outfile<<endl;
}
DWORD m_delay=3000;
Sleep(m_delay);
outfile.close();
cout<<"修改初始化文檔成功!"<<endl;
}

void Allocated_list(void){                         //讀入已分配資源列表
ifstream infile("Allocated_list.txt");
   if(!infile){
cout<<"不能打開輸入文件:"<<"Allocated_list.txt"<<'\n';
exit(1);
}
cout<<"開始讀入已分配資源列表"<<'\n';
int ch,num=0;
int Array[MAX_PROCESS*MAX_COURCE];
while(infile>>ch)
Array[num++]=ch;
num=0;
for(int i=0;i<MAX_FACT_PROCESS;i++)
for(int j=0;j<MAX_FACT_COURCE;j++)
Allocation[i][j]=Array[num++];
infile.close();
}

void Set_Need(void){                        //設置需求矩陣
cout<<"設置需求矩陣"<<'\n';
for(int i=0;i<MAX_FACT_PROCESS;i++)
for(int j=0;j<MAX_FACT_COURCE;j++)
Need[i][j]=Max[i][j]-Allocation[i][j];
}

void Read_Request(void){                           //讀入請求向量
ifstream infile("Request_list.txt");
   if(!infile){
cout<<"不能打開輸入文件:"<<"Request_list.txt"<<'\n';
exit(1);
}
   cout<<"開始讀入請求向量"<<'\n';
int Array[3];
int num=0,ch;
while(infile>>ch)
    Array[num++]=ch;
   Request_PROCESS=Array[0];
   Request_COURCE=Array[1];
   Request_COURCE_NEMBER=Array[2];
infile.close();
}

void Write_Allocation(void){                         //修改資源分配列表(資源分配)
ofstream outfile("Allocated_list.txt");
if(!outfile){
cout<<"不能打開資源分配列表:"<<'\n';
exit(1);
}
for(int i=0;i<MAX_FACT_PROCESS;i++){
for(int j=0;j<MAX_FACT_COURCE;j++)
outfile<<Allocation[i][j]<<" ";
outfile<<endl;
}
   DWORD m_delay=3000;
Sleep(m_delay);
cout<<"修改資源分配列表成功!"<<endl;
outfile.close();
}

void Allocate_Source(void){                       //開始分配(已通過掃描和安全性檢測)
cout<<'\n'<<"開始給第"<<Request_PROCESS<<"個進程分配第"<<Request_COURCE
<<"類資源"<<Request_COURCE_NEMBER<<"個"<<endl;
Write_Initiate();
Write_Allocation();
DWORD m_delay=3000;
Sleep(m_delay);
cout<<'\n'<<"祝賀您,資源分配已成功!"<<endl;
}

void Test_Safty(){                         //安全性檢測
cout<<'\n'<<"進入安全性檢測!"<<endl;
   int Work[MAX_COURCE];
for(int i=0;i<MAX_FACT_COURCE;i++){
Work[i]=Available[i];
}
   bool Finish[MAX_PROCESS][MAX_COURCE];
for(i=0;i<MAX_FACT_PROCESS;i++)
for(int j=0;j<MAX_FACT_COURCE;j++)
Finish[i][j]=false;
COMP Array[32];
for(i=0;i<MAX_FACT_PROCESS;i++)
{
Array[i].value=Need[i][Request_COURCE-1];
       Array[i].num=i;
}
for(i=0;i<MAX_FACT_PROCESS;i++)
for(int j=i+1;j<MAX_FACT_PROCESS;j++){
if(Array[i].value>=Array[j].value){
int t;
t=Array[j].value;
               Array[j].value=Array[i].value;
Array[i].value=t;
t=Array[j].num;
               Array[j].num=Array[i].num;
               Array[i].num=t;
}
else continue;
}
DWORD m_delay=3000;
Sleep(m_delay);
/*for(i=0;i<MAX_FACT_PROCESS;i++){
for(int j=0;j<MAX_FACT_COURCE;j++)
cout<<Need[i][j]<<'\t';
cout<<endl;
}
*/
if(Finish[Request_PROCESS-1][Request_COURCE-1]==false&&Need[Request_PROCESS-1][Request_COURCE-1]<=Work[Request_COURCE-1])
{
Work[Request_COURCE-1]=Work[Request_COURCE-1]+Allocation[Request_PROCESS-1][Request_COURCE-1];
       Finish[Request_PROCESS-1][Request_COURCE-1]=true;
}
else
{
cout<<"未通過安全性測試,不與以分配"<<endl;
exit(0);
}
   for(i=0;i<MAX_FACT_PROCESS;i++){
if(Array[i].num==Request_PROCESS-1)
continue;
if(Array[i].num!=Request_PROCESS-1&&Finish[Array[i].num][Request_COURCE-1]==false&&Need[Array[i].num][Request_COURCE-1]<=Work[Request_COURCE-1]){
Work[Request_COURCE-1]=Work[Request_COURCE-1]+Allocation[Array[i].num][Request_COURCE-1];
               Finish[Array[i].num][Request_COURCE-1]=true;
}
}
   for(i=0;i<MAX_FACT_PROCESS;i++)
{
if(Finish[i][Request_COURCE-1]==true)
continue;
else
{
cout<<"未通過安全性測試,不與以分配"<<endl;
   exit(0);
}
}
cout<<'\n'<<"找到一個安全序列:"<<"P"<<Request_PROCESS<<"--->";
   for(i=0;i<MAX_FACT_PROCESS;i++){
if(Array[i].num==Request_PROCESS)
continue;
else
cout<<"P"<<Array[i].num<<"--->";
}
cout<<'\n'<<"已通過安全性測試!"<<endl;
Allocate_Source();
}

void RUN(void){                                        //執行銀行家算法

   cout<<"*************************************************"<<'\n'<<"點擊1執行!"
<<'\n'<<"點擊2退出!"
<<'\n'<<"*************************************************"<<endl;
cin>>flag;
if(flag==2)
exit(0);
if(flag==1)
{
cout<<"開始掃描請求信息!"<<endl;
DWORD m_delay=3000;
Sleep(m_delay);
if(Request_COURCE_NEMBER>Need[Request_PROCESS-1][Request_COURCE-1])
{
cout<<'\n'<<"第"<<Request_PROCESS<<"個進程請求第"<<Request_COURCE<<"類資源"<<Request_COURCE_NEMBER<<"個"<<endl;
       cout<<"可是已超出該進程尚需的該類資源的最大數量,所以不予以分配!!"<<endl;
exit(0);
}
if(Request_COURCE_NEMBER>Available[Request_COURCE-1])
{
cout<<'\n'<<"第"<<Request_PROCESS<<"個進程請求第"<<Request_COURCE<<"類資源"<<Request_COURCE_NEMBER<<"個"<<endl;
       cout<<"可是系統中尚無足夠的資源,所以進入等待隊列!!"<<endl;
exit(0);
}
   else{
Available[Request_COURCE-1]=Available[Request_COURCE-1]-Request_COURCE_NEMBER;
       Allocation[Request_PROCESS-1][Request_COURCE-1]=Allocation[Request_PROCESS-1][Request_COURCE-1]+Request_COURCE_NEMBER;
       Need[Request_PROCESS-1][Request_COURCE-1]=Need[Request_PROCESS-1][Request_COURCE-1]-Request_COURCE_NEMBER;
cout<<"掃描通過"<<endl;
Sleep(m_delay);
Test_Safty();
}
}
else {
cout<<"輸入錯誤,請重新輸入!"<<'\n';
RUN();
}
}

 

void main(void){
   Read_Initiate();
cout<<MAX_FACT_COURCE<<'\t';
for(int i=0;i<MAX_FACT_COURCE;i++)
cout<<Available[i]<<'\t';
cout<<endl<<MAX_FACT_PROCESS<<endl;
for(i=0;i<MAX_FACT_PROCESS;i++){
for(int j=0;j<MAX_FACT_COURCE;j++)
cout<<Max[i][j]<<'\t';
cout<<endl;
}
DWORD m_delay=3000;
Sleep(m_delay);
cout<<"讀入成功"<<'\n';

Allocated_list();
for(i=0;i<MAX_FACT_PROCESS;i++){
for(int j=0;j<MAX_FACT_COURCE;j++)
cout<<Allocation[i][j]<<'\t';
cout<<endl;
}
Sleep(m_delay);
cout<<"讀入成功"<<'\n';

Set_Need();
   for(i=0;i<MAX_FACT_PROCESS;i++){
for(int j=0;j<MAX_FACT_COURCE;j++)
cout<<Need[i][j]<<'\t';
cout<<endl;
}
   Sleep(m_delay);
cout<<"設置成功"<<'\n';

   Read_Request();
cout<<'\n'<<"第"<<Request_PROCESS<<"個進程請求第"<<Request_COURCE<<"類資源"<<Request_COURCE_NEMBER<<"個"<<endl;
cout<<'\n'<<"讀入成功"<<'\n';

RUN();
}

三.數據測試
注:數組Array[I]表示第I+1個實際意義量
     需要創建三個txt文本。
1.Initiate.txt文本
3 3 3 2      //共有3類資源,Available[0]=3; Available[1]=3; Available[2]=2
5             //當前系統中有個進程
7 5 3         // Max[0][0]=7
3 2 2          //Max[1][1]=3
9 0 2
2 2 2 
4 3 3
2.Allocated_list.txt文本
0 1 0         //Allocation[0][1]=1
2 0 0
3 0 2
2 1 1
0 0 2
3.Request_list.txt文本
2 1 1       //第2個進程請求第1類資源1個Request[1][0]=1
四.程序說明:
本程序假設當前時刻只有一個進程請求某一類資源n個.
若要滿足某個進程當前時刻同時請求不止一類資源,則需要為最大需求矩陣Max,分配矩陣Allocation和需求矩陣Need增加維數,當然代碼量也將大大增加,但是算法邏輯本身并無變化.


 
 
 
[ 收藏此頁到 VIVI | Younote | 365Key | Blogchina | POCO | 人人 | 億友 | 我摘 | 和訊 | 拇指 | 天極 ]  
 
   

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品国产三级国产aⅴ入口 | 午夜久久电影网| 日本美女视频一区二区| 国产99精品国产| 91福利视频久久久久| 久久夜色精品一区| 日韩国产成人精品| 色综合天天综合色综合av | 亚洲国产精华液网站w| 欧美aaaaa成人免费观看视频| 成人99免费视频| 精品日韩一区二区| 日韩电影在线观看电影| 色婷婷av一区二区三区大白胸| 欧美电影免费观看高清完整版在 | 免费成人av资源网| 欧美性猛交一区二区三区精品| 国产精品青草综合久久久久99| 国产综合色视频| 欧美夫妻性生活| 亚洲成a人v欧美综合天堂下载| www.成人在线| 国产精品久久夜| 国产精品资源在线| 精品噜噜噜噜久久久久久久久试看| 性久久久久久久久| 欧美日韩一区二区在线观看 | 久热成人在线视频| 91麻豆精品91久久久久久清纯| 亚洲精品中文字幕在线观看| 国产成人超碰人人澡人人澡| 久久综合九色综合久久久精品综合| 日本不卡的三区四区五区| 555www色欧美视频| 日韩av一级电影| 精品国产一区二区三区不卡 | 精品久久久久香蕉网| 麻豆免费精品视频| 精品久久久久香蕉网| 精品一区二区日韩| 国产人妖乱国产精品人妖| 成人免费视频视频| 亚洲欧洲精品一区二区三区| 91在线porny国产在线看| 亚洲欧美一区二区在线观看| 色屁屁一区二区| 五月天欧美精品| 日韩免费视频线观看| 狠狠色2019综合网| 国产精品成人免费| 欧美日韩免费不卡视频一区二区三区| 亚洲激情图片qvod| 91精品国产综合久久精品图片| 久久精品久久久精品美女| 精品成人在线观看| 91免费观看视频| 日韩经典中文字幕一区| 久久亚洲春色中文字幕久久久| 成人高清视频在线观看| 亚洲电影激情视频网站| 久久综合狠狠综合久久综合88| av不卡一区二区三区| 亚洲一区日韩精品中文字幕| 日韩一区二区三区电影在线观看| 国产成人在线色| 亚洲免费观看高清完整版在线观看熊 | 中文字幕精品综合| 欧美色手机在线观看| 精品一区二区三区欧美| 尤物av一区二区| 日韩精品一区二区三区在线观看| 成人国产在线观看| 日本中文字幕一区二区视频 | 91在线国内视频| 人妖欧美一区二区| 亚洲日本一区二区三区| 日韩一区二区免费在线观看| 成人美女在线观看| 免费成人小视频| 亚洲男人电影天堂| 国产亚洲综合在线| 在线成人av网站| 91色视频在线| 国产成人亚洲精品青草天美| 五月激情丁香一区二区三区| 日韩一区在线看| 国产视频一区二区在线| 日韩一区二区在线观看| 欧美性感一区二区三区| 成人av动漫网站| 极品少妇一区二区三区精品视频| 亚洲伊人伊色伊影伊综合网| 国产精品毛片久久久久久| 日韩女优毛片在线| 91精品国产综合久久久蜜臀粉嫩| 在线观看视频一区二区| 不卡欧美aaaaa| 国产成人在线视频网站| 激情图区综合网| 免费在线观看不卡| 日韩电影在线免费观看| 亚洲大片精品永久免费| 亚洲女子a中天字幕| 国产精品久久久久国产精品日日| 久久综合狠狠综合| 久久久久久久综合色一本| 欧美一区二区女人| 91麻豆精品国产自产在线观看一区 | 欧美日韩一区二区三区免费看| 国产91精品久久久久久久网曝门| 国内精品写真在线观看| 久久精品72免费观看| 三级精品在线观看| 午夜激情一区二区三区| 亚洲国产成人av| 午夜婷婷国产麻豆精品| 丝袜美腿亚洲综合| 日本不卡不码高清免费观看| 蜜臀a∨国产成人精品| 欧美aⅴ一区二区三区视频| 日韩精品一二三区| 蜜乳av一区二区| 激情文学综合插| 国产jizzjizz一区二区| 成人动漫一区二区| 91丨国产丨九色丨pron| 一本高清dvd不卡在线观看| 91久久一区二区| 欧美电影影音先锋| 日韩精品中文字幕在线一区| 精品国产精品一区二区夜夜嗨| 精品av久久707| 国产精品色哟哟| 一区二区三区不卡在线观看 | 欧美成人欧美edvon| 国产视频一区二区在线观看| 成人欧美一区二区三区| 亚洲一区二区欧美| 奇米精品一区二区三区在线观看 | 亚洲精品免费在线观看| 日韩中文字幕91| 国产精品一区一区| 色中色一区二区| 欧美一级日韩免费不卡| 国产亚洲制服色| 一区二区三区国产| 黑人巨大精品欧美黑白配亚洲| 成人国产精品免费| 欧美一区二区在线不卡| 国产欧美精品一区二区三区四区 | 激情综合色播五月| 97久久精品人人爽人人爽蜜臀| 高潮精品一区videoshd| 亚洲欧美国产毛片在线| 日韩亚洲欧美成人一区| 国产精品免费网站在线观看| 亚洲综合在线观看视频| 国产在线视频一区二区| 亚洲午夜免费电影| 国产精品456| 欧美日韩一区二区三区在线| 国产乱码精品一区二区三| 精品久久人人做人人爰| 六月丁香综合在线视频| 91精品午夜视频| 日韩成人dvd| 日韩三级电影网址| 免费美女久久99| 欧美一区二区三区日韩| 日本成人在线不卡视频| 91精品国产免费久久综合| 日韩制服丝袜先锋影音| 日韩一区二区免费在线观看| 精品在线你懂的| 国产亚洲一区二区在线观看| 懂色av一区二区三区蜜臀| 国产精品视频一二三| 99久久精品国产一区二区三区| 亚洲欧美一区二区三区国产精品 | 成人伦理片在线| 亚洲日本在线视频观看| 欧美午夜免费电影| 免费久久精品视频| 中文字幕成人av| 337p日本欧洲亚洲大胆精品| 激情伊人五月天久久综合| 久久色中文字幕| 高清成人在线观看| 亚洲欧洲制服丝袜| 91麻豆精品国产| 激情欧美一区二区三区在线观看| 国产日韩欧美高清在线| 91麻豆国产精品久久| 亚洲一区二区三区视频在线| 欧美一级二级在线观看| 国产精品一卡二| 亚洲激情综合网| 精品国产91亚洲一区二区三区婷婷| 国产精品18久久久久久久久| 亚洲手机成人高清视频|