计算机操作系统实验课实验报告

合集下载

windows的实验报告(完整版)

windows的实验报告(完整版)

windows的实验报告(完整版)实验标题:Windows的实验报告一、实验目的本实验旨在深入了解Windows操作系统的基本原理和功能,并掌握Windows操作系统的安装、配置和使用方法。

二、实验内容1. Windows操作系统的安装通过制作启动盘或使用光盘安装,选择适当的版本和安装选项进行Windows操作系统的安装。

2. Windows操作系统的配置进行系统设置,包括语言和区域设定、时区设定、键盘和鼠标设置等。

3. Windows操作系统的使用掌握Windows操作系统的基本操作,包括桌面管理、文件和文件夹管理、应用程序的安装和卸载、系统设置等。

4. Windows操作系统的网络配置了解并设置Windows操作系统的网络连接,包括有线网络和无线网络的配置。

三、实验步骤1. Windows操作系统的安装按照安装引导界面的指示,选择合适的选项完成安装过程。

注意选择适配的驱动程序并进行相应设置。

2. Windows操作系统的配置在系统设置中,选择适当的语言和区域,设定正确的时区。

根据个人需求,进行键盘和鼠标相关设置。

3. Windows操作系统的使用3.1 桌面管理:了解和使用桌面的基本布局,包括桌面图标的添加、删除、移动等操作。

3.2 文件和文件夹管理:学习使用资源管理器对文件和文件夹进行管理,包括创建、复制、粘贴、删除等操作。

3.3 应用程序的安装和卸载:了解如何通过Windows商店或第三方应用程序进行安装,并学会使用控制面板进行软件的卸载。

3.4 系统设置:掌握系统设置的方法,包括背景壁纸的更换、屏幕分辨率的调整、电源管理等。

4. Windows操作系统的网络配置4.1 有线网络的配置:了解如何通过网线连接计算机和局域网以及设置IP地址、子网掩码等网络参数。

4.2 无线网络的配置:学习如何连接无线网络并进行密码设置,了解无线网络的高级配置选项。

四、实验结果经过以上实验步骤的操作,成功完成了Windows操作系统的安装、配置和使用。

操作系统实验实验报告

操作系统实验实验报告

操作系统实验实验报告一、实验目的操作系统是计算机系统中最为关键的核心软件,它管理着计算机的硬件资源和软件资源,为用户提供了一个方便、高效、稳定的工作环境。

本次操作系统实验的目的在于通过实际操作和实践,深入理解操作系统的基本原理和核心概念,掌握操作系统的基本功能和操作方法,提高对操作系统的认识和应用能力。

二、实验环境本次实验使用的操作系统为 Windows 10 专业版,开发工具为Visual Studio 2019,编程语言为 C 和 C++。

实验硬件环境为一台配备Intel Core i7 处理器、16GB 内存、512GB SSD 硬盘的个人计算机。

三、实验内容(一)进程管理实验1、进程创建与终止通过编程实现创建新的进程,并在完成任务后终止进程。

在实验中,我们使用了 Windows API 函数 CreateProcess 和 TerminateProcess 来完成进程的创建和终止操作。

通过观察进程的创建和终止过程,深入理解了进程的生命周期和状态转换。

2、进程同步与互斥为了实现进程之间的同步与互斥,我们使用了信号量、互斥量等同步对象。

通过编写多线程程序,模拟了多个进程对共享资源的访问,实现了对共享资源的互斥访问和同步操作。

在实验中,我们深刻体会到了进程同步与互斥的重要性,以及不正确的同步操作可能导致的死锁等问题。

(二)内存管理实验1、内存分配与释放使用 Windows API 函数 VirtualAlloc 和 VirtualFree 进行内存的分配和释放操作。

通过实验,了解了内存分配的不同方式(如堆分配、栈分配等)以及内存释放的时机和方法,掌握了内存管理的基本原理和操作技巧。

2、内存分页与分段通过编程模拟内存的分页和分段管理机制,了解了内存分页和分段的基本原理和实现方法。

在实验中,我们实现了简单的内存分页和分段算法,对内存的地址转换和页面置换等过程有了更深入的理解。

(三)文件系统实验1、文件操作使用 Windows API 函数 CreateFile、ReadFile、WriteFile 等进行文件的创建、读取和写入操作。

操作系统实验二实验报告

操作系统实验二实验报告

操作系统实验二实验报告一、实验目的本次操作系统实验二的主要目的是深入理解和掌握进程管理的相关概念和技术,包括进程的创建、执行、同步和通信。

通过实际编程和实验操作,提高对操作系统原理的认识,培养解决实际问题的能力。

二、实验环境本次实验使用的操作系统为 Windows 10,编程环境为 Visual Studio 2019。

三、实验内容及步骤(一)进程创建实验1、首先,创建一个新的 C++项目。

2、在项目中,使用 Windows API 函数`CreateProcess`来创建一个新的进程。

3、为新进程指定可执行文件的路径、命令行参数、进程属性等。

4、编写代码来等待新进程的结束,并获取其退出代码。

(二)进程同步实验1、设计一个生产者消费者问题的模型。

2、使用信号量来实现生产者和消费者进程之间的同步。

3、生产者进程不断生成数据并放入共享缓冲区,当缓冲区已满时等待。

4、消费者进程从共享缓冲区中取出数据进行处理,当缓冲区为空时等待。

(三)进程通信实验1、选择使用管道来实现进程之间的通信。

2、创建一个匿名管道,父进程和子进程分别读写管道的两端。

3、父进程向管道写入数据,子进程从管道读取数据并进行处理。

四、实验结果及分析(一)进程创建实验结果成功创建了新的进程,并能够获取到其退出代码。

通过观察进程的创建和执行过程,加深了对进程概念的理解。

(二)进程同步实验结果通过使用信号量,生产者和消费者进程能够正确地进行同步,避免了缓冲区的溢出和数据的丢失。

分析结果表明,信号量机制有效地解决了进程之间的资源竞争和协调问题。

(三)进程通信实验结果通过管道实现了父进程和子进程之间的数据通信。

数据能够准确地在进程之间传递,验证了管道通信的有效性。

五、遇到的问题及解决方法(一)在进程创建实验中,遇到了参数设置不正确导致进程创建失败的问题。

通过仔细查阅文档和调试,最终正确设置了参数,成功创建了进程。

(二)在进程同步实验中,出现了信号量使用不当导致死锁的情况。

操作系统安全实验1实验报告

操作系统安全实验1实验报告

操作系统安全实验1实验报告一、实验目的本次操作系统安全实验的主要目的是让我们深入了解操作系统的安全机制,通过实际操作和观察,掌握一些常见的操作系统安全配置和防护方法,提高对操作系统安全的认识和应对能力。

二、实验环境本次实验使用的操作系统为Windows 10 和Linux(Ubuntu 2004),实验设备为个人计算机。

三、实验内容与步骤(一)Windows 10 操作系统安全配置1、账户管理创建新用户账户,并设置不同的权限级别,如管理员、标准用户等。

更改账户密码策略,包括密码长度、复杂性要求、密码有效期等。

启用账户锁定策略,设置锁定阈值和锁定时间,以防止暴力破解密码。

2、防火墙配置打开 Windows 防火墙,并设置入站和出站规则。

允许或阻止特定的应用程序通过防火墙进行网络通信。

3、系统更新与补丁管理检查系统更新,安装最新的 Windows 安全补丁和功能更新。

配置自动更新选项,确保系统能够及时获取并安装更新。

4、恶意软件防护安装并启用 Windows Defender 防病毒软件。

进行全盘扫描,检测和清除可能存在的恶意软件。

(二)Linux(Ubuntu 2004)操作系统安全配置1、用户和组管理创建新用户和组,并设置相应的权限和归属。

修改用户密码策略,如密码强度要求等。

2、文件系统权限管理了解文件和目录的权限设置,如读、写、执行权限。

设置特定文件和目录的权限,限制普通用户的访问。

3、 SSH 服务安全配置安装和配置 SSH 服务。

更改 SSH 服务的默认端口号,增强安全性。

禁止 root 用户通过 SSH 登录。

4、防火墙配置(UFW)启用 UFW 防火墙。

添加允许或拒绝的规则,控制网络访问。

四、实验结果与分析(一)Windows 10 操作系统1、账户管理成功创建了具有不同权限的用户账户,并能够根据需求灵活调整权限设置。

严格的密码策略有效地增加了密码的安全性,减少了被破解的风险。

账户锁定策略在一定程度上能够阻止暴力破解攻击。

操作系统实验报告

操作系统实验报告

篇一:操作系统实验报告完全版《计算机操作系统》实验报告班级:姓名:学号:实验一进程控制与描述一、实验目的通过对windows 2000编程,进一步熟悉操作系统的基本概念,较好地理解windows 2000的结构。

通过创建进程、观察正在运行的进程和终止进程的程序设计和调试操作,进一步熟悉操作系统的进程概念,理解windows 2000中进程的“一生”。

二、实验环境硬件环境:计算机一台,局域网环境;软件环境:windows 2000 professional、visual c++6.0企业版。

三、实验内容和步骤第一部分:程序1-1windows 2000 的gui 应用程序windows 2000 professional下的gui应用程序,使用visual c++编译器创建一个gui应用程序,代码中包括了winmain()方法,该方法gui类型的应用程序的标准入口点。

:: messagebox( null, “hello, windows 2000” , “greetings”,mb_ok) ;/* hinstance */ , /* hprevinstance */, /* lpcmdline */, /* ncmdshow */ )return(0) ; }在程序1-1的gui应用程序中,首先需要windows.h头文件,以便获得传送给winmain() 和messagebox() api函数的数据类型定义。

接着的pragma指令指示编译器/连接器找到user32.lib库文件并将其与产生的exe文件连接起来。

这样就可以运行简单的命令行命令cl msgbox.cpp来创建这一应用程序,如果没有pragma指令,则messagebox() api函数就成为未定义的了。

这一指令是visual studio c++ 编译器特有的。

接下来是winmain() 方法。

其中有四个由实际的低级入口点传递来的参数。

计算机操作系统实验报告

计算机操作系统实验报告

计算机操作系统实验报告一、实验目的本次计算机操作系统实验的主要目的是深入了解操作系统的工作原理和功能,通过实际操作和观察,增强对操作系统概念的理解,提高解决实际问题的能力。

二、实验环境1、操作系统:Windows 10 专业版2、开发工具:Visual Studio 20193、编程语言:C++三、实验内容1、进程管理实验创建多个进程,并观察它们的执行顺序和资源占用情况。

使用进程控制块(PCB)来跟踪进程的状态变化,如就绪、运行、阻塞等。

2、内存管理实验模拟内存分配和回收算法,如首次适应算法、最佳适应算法和最坏适应算法。

观察不同算法在内存利用率和分配效率方面的表现。

3、文件系统实验创建、读取、写入和删除文件,了解文件的操作流程。

研究文件的存储结构和目录管理方式。

4、线程同步与互斥实验使用互斥锁和信号量来实现线程之间的同步和互斥操作。

观察在多线程环境下资源竞争和同步的效果。

四、实验步骤1、进程管理实验步骤编写 C++程序,使用系统调用创建多个进程。

在每个进程中输出进程的标识符和当前执行时间。

通过观察控制台输出,分析进程的执行顺序和资源占用情况。

2、内存管理实验步骤实现不同的内存分配算法,并在程序中模拟内存请求和释放的过程。

记录每次内存分配和回收的结果,计算内存利用率和分配时间。

3、文件系统实验步骤使用文件操作函数创建文件,并写入一些数据。

读取文件中的数据,并将其输出到控制台。

删除文件,观察文件系统的变化。

4、线程同步与互斥实验步骤创建多个线程,共享一些公共资源。

在访问公共资源的代码段前使用互斥锁或信号量进行同步控制。

观察线程的执行结果,确保资源的正确访问和修改。

五、实验结果与分析1、进程管理实验结果与分析实验结果显示,进程的执行顺序是不确定的,取决于操作系统的调度策略和进程的优先级。

资源占用情况也因进程的不同而有所差异,一些进程可能占用较多的 CPU 时间和内存,而另一些则相对较少。

2、内存管理实验结果与分析首次适应算法在分配速度上较快,但容易产生内存碎片。

华科操作系统实验报告

华科操作系统实验报告

华科操作系统实验报告一、实验目的操作系统是计算机系统的核心组成部分,对于理解计算机的工作原理和提高计算机应用能力具有重要意义。

本次华科操作系统实验的主要目的是通过实际操作和实践,深入理解操作系统的基本概念、原理和功能,掌握操作系统的核心技术和应用方法,提高我们的实践能力和问题解决能力。

二、实验环境本次实验使用的操作系统为Windows 10 和Linux(Ubuntu 2004),开发工具包括 Visual Studio Code、GCC 编译器等。

实验硬件环境为个人计算机,配置为英特尔酷睿 i7 处理器、16GB 内存、512GB 固态硬盘。

三、实验内容1、进程管理进程创建与销毁进程调度算法模拟进程同步与互斥2、内存管理内存分配与回收算法实现虚拟内存管理3、文件系统文件操作与管理文件系统的实现与优化4、设备管理设备驱动程序编写设备分配与回收四、实验步骤及结果1、进程管理实验进程创建与销毁首先,使用 C 语言编写程序,通过系统调用创建新的进程。

在程序中,使用 fork()函数创建子进程,并在子进程和父进程中分别输出不同的信息,以验证进程的创建和执行。

实验结果表明,子进程和父进程能够独立运行,并输出相应的信息。

进程调度算法模拟实现了先来先服务(FCFS)、短作业优先(SJF)和时间片轮转(RR)三种进程调度算法。

通过模拟多个进程的到达时间、服务时间和优先级等参数,计算不同调度算法下的平均周转时间和平均等待时间。

实验结果显示,SJF 算法在平均周转时间和平均等待时间方面表现较好,而 RR 算法能够提供较好的响应时间和公平性。

进程同步与互斥使用信号量和互斥锁实现了进程的同步与互斥。

编写了生产者消费者问题的程序,通过信号量控制生产者和消费者对缓冲区的访问,避免了数据竞争和不一致的情况。

实验结果表明,信号量和互斥锁能够有效地实现进程间的同步与互斥,保证程序的正确性。

2、内存管理实验内存分配与回收算法实现实现了首次适应(First Fit)、最佳适应(Best Fit)和最坏适应(Worst Fit)三种内存分配算法。

计算机操作系统实验课实验报告

计算机操作系统实验课实验报告

计算机操作系统实验课实验报告实验报告实验课程:计算机操作系统学生姓名:XXX学号:XXXX专业班级:软件2022年年12月月25日目录实验一熟悉PWindowsXP中的进程与线程..1实验二进程调度............................................4实验三死锁避免—银行家算法的实现......13实验四存储管理..........................................19实验一熟悉PWindowsXP中的进程与线程一、实验名称熟悉WindowsXP中的进程与线程二、实验目的1、熟悉Windows中任务管理器的使用。

2、通过任务管理器识别操作系统中的进程与线程的相关信息。

3、掌握利用spy++、exe来察瞧Windows中各个任务的更详细信息。

三、实验结果分析1、启动操作系统自带的任务管理器:方法:直接按组合键Ctrl+Alt+Del,或者就是在点击任务条上的“开始”“运行”,并输入“taskmgr、exe”。

2、调整任务管理器的“查瞧”中的相关设置,显示关于进程的以下各项信息,并完成下表:表一:统计进程的各项主要信息序号进程名称进程ID 线程数量占用内存优先级占CPU时间虚拟内存1Bddownloader、exe7312329980k标准0:00:009200k2Taskmgr、exe722834124k高0:00:043372k3BaiDuSdTray、exe5144308588k标准0:00:1543652k 任务管理器无法结束进程,原因就是该系统就是系统进程。

4、在任务管理器中找到进程“explorer、exe”,将之结束掉,并将桌面上您打开的所有窗口最小化,瞧瞧您的计算机系统起来什么样的变化桌面上图标菜单都消失了、得到的结论explorer、exe就是管理桌面图标的文件(说出explorer、exe进程的作用)。

5、运行“spy++、exe”应用软件,点击按钮“”,切换到进程显示栏上,查瞧进程“explorer、exe”的各项信息,并填写下表:进程:explorer、exe中的各个线程序号进程ID线程ID基本优先级当前优先级CPU时间上下文开关1000016B88100:00:0649983362000016B8000003EC15150:00:0083000016B88100:00:00114000016B800000A0C8100:00:00135000016B8880:00:078171386000016B8000013D88100:00:0023266、注意某些线程前有“+”,如图所示:,说明二者之间的差异前有“+”其器线程下有窗口。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

实验报告实验课程: 计算机操作系统学生姓名:XXX学号:XXXX专业班级:软件2014年12月25日目录实验一熟悉Windows XP中的进程和线程.. 3实验二进程调度 (7)实验三死锁避免—银行家算法的实现 (18)实验四存储管理 (24)实验一熟悉Windows XP中的进程和线程一、实验名称熟悉Windows XP中的进程和线程二、实验目的1、熟悉Windows中任务管理器的使用。

2、通过任务管理器识别操作系统中的进程和线程的相关信息。

3、掌握利用spy++.exe来察看Windows中各个任务的更详细信息。

三、实验结果分析1、启动操作系统自带的任务管理器:方法:直接按组合键Ctrl+Alt+Del,或者是在点击任务条上的“开始”“运行”,并输入“taskmgr.exe”。

2、调整任务管理器的“查看”中的相关设置,显示关于进程的以下各项信息,并完成下表:表一:统计进程的各项主要信息3、启动办公软件“Word”,在任务管理器中找到该软件的登记,并将其结束掉。

再从任务管理器中分别找到下列程序:winlogon.exe、lsass.exe、csrss.exe、smss.exe,试着结束它们,观察到的反应是任务管理器无法结束进程,原因是该系统是系统进程。

4、在任务管理器中找到进程“explorer.exe”,将之结束掉,并将桌面上你打开的所有窗口最小化,看看你的计算机系统起来什么样的变化桌面上图标菜单都消失了、得到的结论explorer.exe是管理桌面图标的文件(说出explorer.exe进程的作用)。

5、运行“spy++.exe”应用软件,点击按钮“”,切换到进程显示栏上,查看进程“explorer.exe”的各项信息,并填写下表:进程:explorer.exe 中的各个线程6、注意某些线程前有“+”,如图所示:,说明二者之间的差异前有“+”其器线程下有窗口。

四、心得体会通过本次实验,我了解到了windows系统中进程的管理与操作,我了解了如何切出任务管理器,任务管理器应用与其他与进程相关的知识,明白了有些系统程序不能够关闭,系统中的进程与线程虽然很多,但是其中有许多关联,只要弄清楚其中的关联那么就能够运用好进程与线程,达到我们的目的。

每个进程下都包含着许多线程,我们控制进程来达到控制线程的目的只有我们了解好掌握还进程,我们才能更好的运用线程,更好的控制运用计算机。

实验二进程调度一、实验名称进程调度二、实验目的1、使学生进一步理解进程的概念,并在此基础上掌握有关PCB、进程队列的概念。

2、掌握进程基本状态的转化;3、掌握进程调度的策略、具体实施方法以及系统性能的评价方法。

三、实验结果分析简化的实验代码如下:#include<iostream>#include<queue>//调用STL中的优先队列using namespace std;//定义一个PCB进程类class PCB{public:char name[10];//进程的名字int runtime;//该进程的运行时间int priority;//该进程的优先级char state;//该进程的状态PCB* next;//指向下个进程的指针void print()const//输出进程的信息{cout<<"(name="<<name<<",runtime="<<runtime<<",state="<<state<<",priority="<<priority<<")"<<endl;}};class PCBSortCriterion{//优先队列的优先准则类public:bool operator()(const PCB & p1,const PCB & p2)const//仿函数确定优先准则,从大到小{return (p1.priority < p2.priority);}};PCB* pcb=new PCB[number];//一个PCB的数组用来保存就绪进程PCB* p1=new PCB[number];//一个PCB的数组用来保存已经结束的进程cout<<endl;PCB p;//一个PCB型的变量,用来保存队首元素int i;for( i=0 ;i<=number-1;i++)//建立进程信息cout<<"请输入pcb["<<i<<"]的信息!"<<endl;cout<<"以(name,runtime,state(初始为R),priority)格式输入!"<<endl;cin>>pcb[i].name;cin>>pcb[i].runtime;cin>>pcb[i].state;cin>>pcb[i].priority;cout<<endl;}typedef priority_queue<PCB,vector<PCB> ,PCBSortCriterion> pQueue;//以//PCBSortCriterion为//优先准则的优先队列pQueue q,// 优先队列pQueue的一个对象,对这个队列进行主操作temp;//优先队列pQueue的一个对象,是q的一个拷贝对象,作为实现打印输出//的一个中间变量for(int j=0;j<=number-1;j++)//将进程入队建立优先队列{q.push(pcb[j]);}//输出进程控制块的初始状态信息cout<<"进程控制块的初始状态信息为:"<<endl;temp=q;while(!temp.empty()){p=temp.top();p.print();temp.pop();}cout<<endl;int n=0, //进程执行的次数m=0;//完成进程的个数while(!q.empty())//对进程进行调度{cout<<"第"<<++n<<"次运行";p=q.top();cout<<q.top().name<<"!"<<endl;p.runtime-=1;p.priority-=1;q.pop();if(p.runtime!=0)//表明该进程还未执行完,继续入队进行操作{q.push(p);}else {//表明该进程已经执行完,设置其状态为Z,并将其保存到p1中p.state='Z';p1[m++]=p;}cout<<"运行后的状态为:"<<endl;//打印出运行后的进程状态temp=q;//拷贝输出队列while(!temp.empty()){p=temp.top();p.print();temp.pop();}if(m>0)//输出完成的进程的信息for( i=0;i<=m-1;i++)p1[i].print();cout<<endl;cout<<endl;}system("pause");return 0;}int main(){cout<<setw(40)<<"进程模拟调度设计"<<endl<<endl;cout<<"提示:输入1选择先来先服务算法,输入2选择优先级法,输入3选择轮转法,输入4退出程序"<<endl<<endl;cout<<" 1、先来先服务\n 2、优先级法\n 3、时间片轮转法\n 4.多级反馈轮转法\n 5.动态优先级法\n 6.退出"<<endl<<endl;int choice;int go=1;while(go){cout<<"请输入你的选择:";cin>>choice;switch(choice){//调用先来先服务算法求解case 1: FCFS();break;//调用优先级法求解case 2: PRIO();break;//调用时间片轮转法求解case 3: LZF();break;//调用多级反馈轮转法求解case 4: DJFKLZ();break;case 5: DTYXJF();break;case 6: cout<<"退出"<<endl;go=0;break;//返回首页default: cout<<"选择有误,请重新输入选择!"<<endl;break;}}system("pause");return 0;}程序运行结果:初始化界面:先来先服务法:静态优先级法:时间片轮转法:.动态优先级法:多级反馈轮转法:四、心得体会1、通过这次实验使得我对进程调度几种算法的思想以及实现原理有了进一步的认识和掌握。

在设计多级反馈轮转法的算法以及实现代码时,遇到了代码不会写,算法理解不够透彻的问题,而导致在这个问题上纠结了很久。

最后还是在查阅资料以及同组成员的讨论下解决了。

2、这次实验使用的编程语言是C。

由于在以前学习C的时候掌握的不是很好和很多知识点都忘记了以至于在实验的很多地方(如实验界面和代码的精简)做得不是很好,以后得注意对C的学习和巩固。

3、也使我更能体会到集体的力量永远要大于个人。

在实验中我们遇见的很多问题基本上都是一起讨论才解决的。

4.一开始以为涉及到操作系统的模拟编程的都是高不可攀的,然而在仔细阅读课本以及实验说明后,发现只要弄清楚了优先级数调度的实现原理后其实并不难,用优先队列就可以了。

通过这个实验一来加深了对优先级数调度的理解,二来也加强了自己的编程实践能力!实验三死锁避免—银行家算法的实现一、实验名称死锁避免—银行家算法的实现二、实验目的1、掌握死锁产生的原因和必要条件。

2、掌握银行家算法的实现三、实验结果分析#include <iostream>using namespace std;#define mp 50 //最大进程数#define mr 100 /最大资源数int keyong[mr]; //可用资源数组int MAX[mp][mr]; //最大需求矩阵int fenpei[mp][mr]; //分配矩阵int need[mp][mr]; //剩余需求矩阵bool FINISH[mp]; //系统是否有足够资源分配int p[mp]; //记录序列int Work[mr]; //工作数组int m,n; //m个进程,n个资源int l=0;void Init(); //初始化bool Safe();void jc();void main(){ Init();Safe();if(l!=m)jc();}void Init() //初始化算法{ int i,j;cout<<"请输入进程的数目:";cin>>m;cout<<"请输入资源的种类:";cin>>n;cout<<"请输入每个进程最多所需的各资源数,按照"<<m<<"x"<<n<<"矩阵输入"<<endl;for(i=0;i<m;i++)for(j=0;j<n;j++)cin>>MAX[i][j];cout<<"请输入每个进程已分配的各资源数,也按照"<<m<<"x"<<n<<"矩阵输入"<<endl;for(i=0;i<m;i++){ for(j=0;j<n;j++){cin>>fenpei[i][j];need[i][j]=MAX[i][j]-fenpei[i][j];if(need[i][j]<0){ cout<<"您输入的第"<<i+1<<"个进程所拥有的第"<<j+1<<"个资源数错误,请重新输入:"<<endl; j--;continue; }}}cout<<"请输入各个资源现有的数目:"<<endl;for(i=0;i<n;i++){ cin>>keyong[i]; }cout<<"剩余需求矩阵:"<<endl;for(i=0;i<m;i++)for(j=0;j<n;j++){ cout<<need[i][j]<<" ";if(j==n-1)cout<<endl;}cout<<"各资源现有数量:"<<endl;for(i=0;i<n;i++)cout<<keyong[i]<<" ";cout<<endl;}bool Safe() /*安全性算法*/{ int i,j,k;for(i=0;i<n;i++)Work[i]=keyong[i];for(i=0;i<m;i++){ FINISH[i]=false; //判断进程i是否已执行}for(i=0;i<m;i++){if(FINISH[i]==true){ continue;}else{ for(j=0;j<n;j++){ if(need[i][j]>Work[j]){ break;}}if(j==n){ FINISH[i]=true;for(k=0;k<n;k++){ Work[k]+=fenpei[i][k]; //进程i执行完后回收资源}p[l++]=i;i=-1;}else{continue;}}if(l==m){cout<<"系统是安全的"<<endl;cout<<"安全序列:"<<endl;for(i=0;i<l;i++){cout<<p[i];if(i!=l-1){cout<<"-->";}}cout<<""<<endl;return true;}}cout<<"会发生死锁,发生死锁的进程是:"<<endl;for(i=0;i<m;i++)if(FINISH[i]==false)cout<<i<<" ";cout<<endl;return false;}void jc(){int i,j,k,q;i=0;while(i<m&&FINISH[i]==false) //寻找没执行的{for(j=0;j<n;j++){keyong[j]+=fenpei[i][j]; //回收fenpei[i][j]=0;}if(Safe())cout<<"死锁已解除"<<endl;elsei++;Safe();}}输入四、心得体会通过这次实验,我了解了有关资源申请分配、检测以及避免死锁等概念,了解死锁和避免死锁的具体实施方法。

相关文档
最新文档