操作系统实验报告-利用银行家算法避免死锁

上传人:bei****lei 文档编号:136041092 上传时间:2022-08-16 格式:DOC 页数:20 大小:418.50KB
收藏 版权申诉 举报 下载
操作系统实验报告-利用银行家算法避免死锁_第1页
第1页 / 共20页
操作系统实验报告-利用银行家算法避免死锁_第2页
第2页 / 共20页
操作系统实验报告-利用银行家算法避免死锁_第3页
第3页 / 共20页
资源描述:

《操作系统实验报告-利用银行家算法避免死锁》由会员分享,可在线阅读,更多相关《操作系统实验报告-利用银行家算法避免死锁(20页珍藏版)》请在装配图网上搜索。

1、 计算机操作系统实验报告题 目 利用银行家算法避免死锁 一、 实验目的: 1、加深了解有关资源申请、避免死锁等概念,并体会和了解死锁和避免死锁的具体实施方法。 2、要求编写和调试一个系统动态分配资源的简单模拟程序,观察死锁产生的条件,并采用银行家算法,有效的防止和避免死锁的发生。二、 实验内容: 用银行家算法实现资源分配: 设计五个进程p0,p1,p2,p3,p4共享三类资源A,B,C的系统,例如,A,B,C的资源数量分别为10,5,7。进程可动态地申请资源和释放资源,系统按进程的申请动态地分配资源,要求程序具有显示和打印各进程的某一个时刻的资源分配表和安全序列;显示和打印各进程依次要求申请的

2、资源号以及为某进程分配资源后的有关资源数据。三、 问题分析与设计:1、算法思路:先对用户提出的请求进行合法性检查,即检查请求是否大于需要的,是否大于可利用的。若请求合法,则进行预分配,对分配后的状态调用安全性算法进行检查。若安全,则分配;若不安全,则拒绝申请,恢复到原来的状态,拒绝申请。2、银行家算法步骤:(1)如果Requestior =Need,则转向步骤(2);否则,认为出错,因为它所需要的资源数已超过它所宣布的最大值。 (2)如果Requestor=Available,则转向步骤(3);否则,表示系统中尚无足够的资源,进程必须等待。 (3)系统试探把要求的资源分配给进程Pi,并修改下面

3、数据结构中的数值: Available=Available-Requesti; Allocation=Allocation+Request; Need=Need-Request; (4)系统执行安全性算法,检查此次资源分配后,系统是否处于安全状态。3、安全性算法步骤:(1)设置两个向量 工作向量Work。它表示系统可提供进程继续运行所需要的各类资源数目,执行安全算法开始时,Work=Allocation; 布尔向量Finish。它表示系统是否有足够的资源分配给进程,使之运行完成,开始时先做Finishi=false,当有足够资源分配给进程时,令Finishi=true。(2)从进程集合中找到一

4、个能满足下述条件的进程: Finishi=false Needor=Work 如找到,执行步骤(3);否则,执行步骤(4)。(3)当进程P获得资源后,可顺利执行,直至完成,并释放出分配给它的资源,故应执行: Work=Work+Allocation; Finishi=true; 转向步骤(2)。(4)如果所有进程的Finishi=true,则表示系统处于安全状态;否则,系统处于不安全状态。4、流程图:系统主要过程流程图银行家算法流程图安全性算法流程图5、主要数据结构 假设有M个进程N类资源,则有如下数据结构:int maxM*N M个进程对N类资源的最大需求量int availableN 系统

5、可用资源数int allocatedM*N M个进程已经得到N类资源的资源量int needM*N M个进程还需要N类资源的资源量int worked 系统提供给进程继续运行所需的各类资源数目 四、 源代码import java.awt.*;import javax.swing.*;import java.util.*;import java.awt.event.*;import javax.swing.border.*;public class OsBanker extends JFrame / 界面设计JLabel labelInfo;JLabel labelInfo1;int resou

6、rceNum, processNum;int count = 0;JButton buttonRequest, buttonSetInit, button, button1, buttonsearch,button2;JTextField tf1, tf2;JTextField textAvailable;JTextField textAllocation;JTextField textNeed;JTextField textProcessName;JTextField textRequest;int available;int max;int need;int allocated;int S

7、afeSequence;int request;boolean Finish;int worked;boolean flag = false;JFrame f1;JFrame f2;JFrame f3;JTextArea jt;void display() Border border = BorderFactory.createLoweredBevelBorder();Border borderTitled = BorderFactory.createTitledBorder(border, 按钮区);textAvailable = new JTextField5;textAllocation

8、 = new JTextField65;textNeed = new JTextField65;textProcessName = new JTextField();textProcessName.setEnabled(false);textRequest = new JTextField5;tf1 = new JTextField(20);tf2 = new JTextField(20);labelInfo = new JLabel(请先输入资源个数和进程个数(16),后单击确定);JPanel contentPane;contentPane = (JPanel) this.getConte

9、ntPane();contentPane.setLayout(null);contentPane.setBackground(Color.pink);labelInfo.setBounds(50, 10, 300, 40);labelInfo.setOpaque(true);labelInfo.setForeground(Color.red);labelInfo.setBackground(Color.pink);contentPane.add(labelInfo, null);JLabel b1 = new JLabel(资源个数:);b1.setForeground(Color.blue)

10、;JLabel b2 = new JLabel(进程个数:);b2.setForeground(Color.blue);b1.setBounds(50, 80, 80, 30);contentPane.add(b1, null);tf1.setBounds(180, 80, 170, 30);contentPane.add(tf1, null);b2.setBounds(50, 150, 80, 30);contentPane.add(b2, null);tf2.setBounds(180, 150, 170, 30);contentPane.add(tf2, null);button1 =

11、new JButton(确定);button = new JButton(重置);button1.setBounds(80, 200, 80, 30);contentPane.add(button1, null);button.setBounds(220, 200, 80, 30);contentPane.add(button, null);this.setSize(400, 300);this.setResizable(false);this.setTitle(银行家算法(SXJ);this.setLocationRelativeTo(null);this.setDefaultCloseOp

12、eration(EXIT_ON_CLOSE);this.setVisible(true);f1 = new JFrame();labelInfo1 = new JLabel(请先输入最大需求和分配矩阵,然后单击初始化);JPanel contentPane1;contentPane1 = (JPanel) f1.getContentPane();contentPane1.setLayout(null);contentPane1.setBackground(Color.pink);labelInfo1.setOpaque(true);labelInfo1.setBounds(75, 10, 40

13、0, 40);labelInfo1.setBackground(Color.pink);labelInfo1.setForeground(Color.blue);contentPane1.add(labelInfo1, null);JLabel labelAvailableLabel = new JLabel(AllResource:);JLabel labelNeedLabel = new JLabel(MaxNeed:);JLabel labelAllocationLabel = new JLabel(allocated:);JLabel labelRequestLabel = new J

14、Label(request process:);labelNeedLabel.setBounds(75, 90, 100, 20);/ x,y,width,heightcontentPane1.add(labelNeedLabel, null);labelAllocationLabel.setBounds(75, 240, 100, 20);contentPane1.add(labelAllocationLabel, null);labelAvailableLabel.setBounds(75, 70, 100, 20);contentPane1.add(labelAvailableLabel

15、, null);labelRequestLabel.setBounds(75, 400, 100, 20);contentPane1.add(labelRequestLabel, null);JLabel labelProcessLabel1 = new JLabel(进程1), new JLabel(进程2),new JLabel(进程3), new JLabel(进程4), new JLabel(进程5),new JLabel(进程6) ;JLabel labelProcessLabel2 = new JLabel(进程1), new JLabel(进程2),new JLabel(进程3)

16、, new JLabel(进程4), new JLabel(进程5),new JLabel(进程6) ;JPanel pPanel1 = new JPanel(), pPanel2 = new JPanel(), pPanel3 = new JPanel(), pPanel4 = new JPanel();pPanel1.setLayout(null);pPanel2.setLayout(null);/* * pPanel4.setLayout(null); pPanel4.setBounds(440,120,90,270); * pPanel4.setBorder(borderTitled)

17、; */buttonSetInit = new JButton(初始化);buttonsearch = new JButton(检测安全性);button2 = new JButton(重置);buttonRequest = new JButton(请求资源);buttonSetInit.setBounds(420, 140, 100, 30);contentPane1.add(buttonSetInit, null);buttonsearch.setBounds(420, 240, 100, 30);contentPane1.add(buttonsearch, null);button2.s

18、etBounds(420, 340, 100, 30);contentPane1.add(button2, null);buttonRequest.setBounds(420, 425, 100, 30);contentPane1.add(buttonRequest, null);for (int pi = 0; pi 6; pi+) labelProcessLabel1pi.setBounds(0, 0 + pi * 20, 60, 20);labelProcessLabel2pi.setBounds(0, 0 + pi * 20, 60, 20);pPanel1.setBounds(75,

19、 120, 60, 120);pPanel2.setBounds(75, 270, 60, 120);for (int pi = 0; pi 6; pi+) pPanel1.add(labelProcessLabel1pi, null);pPanel2.add(labelProcessLabel2pi, null);contentPane1.add(pPanel1);contentPane1.add(pPanel2);contentPane1.add(pPanel4);for (int si = 0; si 5; si+)for (int pi = 0; pi 6; pi+) textNeed

20、pisi = new JTextField();textNeedpisi.setBounds(150 + si * 50, 120 + pi * 20, 50, 20);textNeedpisi.setEditable(false);textAllocationpisi = new JTextField();textAllocationpisi.setBounds(150 + si * 50, 270 + pi * 20,50, 20);textAllocationpisi.setEditable(false);for (int si = 0; si 5; si+) textAvailable

21、si = new JTextField();textAvailablesi.setEditable(false);textAvailablesi.setBounds(150 + si * 50, 70, 50, 20);textRequestsi = new JTextField();textRequestsi.setEditable(false);textRequestsi.setBounds(150 + si * 50, 430, 50, 20);contentPane1.add(textAvailablesi, null);contentPane1.add(textRequestsi,

22、null);for (int pi = 0; pi 6; pi+)for (int si = 0; si 5; si+) contentPane1.add(textNeedpisi, null);contentPane1.add(textAllocationpisi, null);textProcessName.setBounds(80, 430, 50, 20);contentPane1.add(textProcessName, null);f1.setSize(550, 500);f1.setResizable(false);f1.setTitle(银行家算法(SXJ);f1.setLoc

23、ationRelativeTo(null);f1.setDefaultCloseOperation(EXIT_ON_CLOSE);/ f1.setVisible(true);f1.setVisible(false);f2 = new JFrame(安全序列显示框);jt = new JTextArea(75, 40);jt.setBackground(Color.pink);jt.setForeground(Color.blue);JScrollPane scrollPane = new JScrollPane(jt); / 加滚动条scrollPane.setBorder(BorderFac

24、tory.createLoweredBevelBorder();/ 边界(f2.getContentPane().add(scrollPane);f2.setSize(450, 400);f2.setResizable(false);f2.setDefaultCloseOperation(EXIT_ON_CLOSE);f2.setVisible(false);buttonSetInit.setEnabled(false);buttonRequest.setEnabled(false);buttonsearch.setEnabled(false);button1.addActionListene

25、r(new ActionListener() public void actionPerformed(ActionEvent e) / labelInfo.setText(请先初始化allocated和Maxneed,后单击初始化按钮);f1.setVisible(true);buttonSetInit.setEnabled(true);resourceNum = Integer.parseInt(tf1.getText();processNum = Integer.parseInt(tf2.getText();for (int i = 0; i processNum; i+) for (in

26、t j = 0; j resourceNum; j+) textNeedij.setEditable(true);textAllocationij.setEditable(true);textAvailablej.setEditable(true););buttonSetInit.addActionListener(new ActionListener() public void actionPerformed(ActionEvent e) Init();buttonsearch.setEnabled(true););buttonsearch.addActionListener(new Act

27、ionListener() public void actionPerformed(ActionEvent e) count = 0;SafeSequence = new intprocessNum;worked = new intresourceNum;Finish = new booleanprocessNum;copyVector(worked, available);Safety(0);jt.append(安全序列数量: + count);if (flag) labelInfo1.setText(当前系统状态:安全);f2.setVisible(true);buttonRequest.

28、setEnabled(true);textProcessName.setEnabled(true);for (int i = 0; i resourceNum; i+) textRequesti.setEditable(true); else labelInfo1.setText(当前系统状态:不安全);buttonSetInit.setEnabled(false););buttonRequest.addActionListener(new ActionListener() public void actionPerformed(ActionEvent e) count = 0;for (in

29、t i = 0; i processNum; i+) Finishi = false;jt.setText();flag = false;RequestResource(););button2.addActionListener(new ActionListener() public void actionPerformed(ActionEvent e) /* * tf1.setText(); tf2.setText(); */f2.setVisible(false);jt.setText();for (int i = 0; i processNum; i+) for (int j = 0;

30、j resourceNum; j+) textNeedij.setText();textAllocationij.setText();textAvailablej.setText();textRequestj.setText();/ textNeedij.setEditable(false);/ textAllocationij.setEditable(false);/ textAvailablej.setEditable(false);textRequestj.setEditable(false);textProcessName.setText();Finishi = false;flag

31、= false;buttonsearch.setEnabled(false);/ labelInfo.setText(请先输入资源个数和进程个数,后单击确定););button.addActionListener(new ActionListener() public void actionPerformed(ActionEvent e) tf1.setText();tf2.setText();f2.setVisible(false);jt.setText();flag = false;);void copyVector(int v1, int v2) for (int i = 0; i v1

32、.length; i+)v1i = v2i;void Add(int v1, int v2) for (int i = 0; i v1.length; i+)v1i += v2i;void Sub(int v1, int v2) for (int i = 0; i v1.length; i+)v1i -= v2i;boolean Smaller(int v1, int v2) boolean value = true;for (int i = 0; i v2i) value = false;break;return value;public static void main(String ar

33、gs) OsBanker ob = new OsBanker();ob.display();/ System.out.println( +count);void Init() / 初始化操作矩阵available = new intresourceNum;for (int i = 0; i resourceNum; i+) availablei = Integer.parseInt(textAvailablei.getText();max = new intprocessNumresourceNum;allocated = new intprocessNumresourceNum;need =

34、 new intprocessNumresourceNum;for (int i = 0; i processNum; i+) for (int j = 0; j resourceNum; j+) maxij = Integer.parseInt(textNeedij.getText();allocatedij = Integer.parseInt(textAllocationij.getText();for (int i = 0; i resourceNum; i+)for (int j = 0; j processNum; j+)needji = maxji - allocatedji;f

35、or (int i = 0; i resourceNum; i+)for (int j = 0; j processNum; j+) availablei -= allocatedji;if (availablei 0) labelInfo.setText(您输入的数据有误,请重新输入);void Safety(int n) / 查找所有安全序列if (n = processNum) count+;for (int i = 0; i processNum; i+) jt.append(进程 + (SafeSequencei + 1) + );jt.append(n);flag = true;r

36、eturn;for (int i = 0; i processNum; i+) if (Finishi = false) boolean OK = true;for (int j = 0; j workedj) OK = false;break;if (OK) for (int j = 0; j resourceNum; j+) workedj += allocatedij;Finishi = true;SafeSequencen = i;Safety(n + 1);Finishi = false;SafeSequencen = -1;/ num+;for (int j = 0; j reso

37、urceNum; j+) workedj -= allocatedij;void RequestResource() / 请求资源jt.setText();int processname = (Integer.parseInt(textProcessName.getText() - 1);request = new intresourceNum;for (int i = 0; i resourceNum; i+) requesti = Integer.parseInt(textRequesti.getText();if (!Smaller(request, needprocessname) l

38、abelInfo.setText(资源请求不符该进程的需求量.); else if (!Smaller(request, available) labelInfo1.setText(可用资源不足以满足请求,进程需要等待.); else Sub(available, request);Add(allocatedprocessname, request);Sub(needprocessname, request);copyVector(worked, available);Safety(0);if (flag) labelInfo1.setText(可立即分配给该进程!); else labelI

39、nfo1.setText(分配后导致系统处于不安全状态!,不可立即分配);Add(available, request);Sub(allocatedprocessname, request);Add(needprocessname, request);/ 五、 实验结果: 初始界面: 初始化:检测安全性:请求资源:(1)进程2(1,0,2)(2)进程5(3,3,0)(3)进程1(0,2,0)六、 遇到的问题及不足之处:1、程序编写的时候规定最大资源数和最大进程数均=6。2、程序直接初始化了6个进程框,既浪费了内存空间,又对可视化界面的美观造成影响。3、未对输入异常进行处理:比如在请求资源的第一个方框中只能填入进程的数字编号,当填入的为非整数时,程序会抛出异常。4、未解决进程名中对字符串的处理,直接固定进程名为数字,用户不能直接输入原有的进程名,造成不好的用户体验。

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!