操作系统实践报告
- 格式:doc
- 大小:645.50 KB
- 文档页数:18
操作系统实习报告一、引言操作系统是计算机系统中的核心软件之一,扮演着管理和控制计算机硬件资源的重要角色。
为了更深入地了解和掌握操作系统的实际应用,我参加了一次为期两个月的操作系统实习。
本报告将对实习的内容、所学到的知识和经验进行总结和分享。
二、实习背景实习期间,我加入了一家知名互联网公司的技术部门,并被分配到操作系统团队。
该团队负责研发和维护公司内部使用的自主开发操作系统,以及对外提供技术支持。
三、实习内容1. 参与操作系统开发和维护:在实习期间,我积极参与公司操作系统的开发和维护工作。
这包括与其他团队成员合作,分析和解决操作系统的bug,以及根据需求进行功能增强和改进。
2. 系统性能优化:我还参与了一些系统性能优化的工作。
通过分析和测试,我学会了如何定位和解决系统性能瓶颈,并提出相应的优化建议。
这让我对操作系统的内部原理和工作机制有了更深入的了解。
3. 用户支持和故障排除:作为操作系统团队的一员,我还负责为公司内部的员工提供操作系统相关的技术支持。
这包括回答用户的问题、解决操作系统相关的故障以及编写相关技术文档。
四、实习收获1. 增强操作系统的理论知识:通过实习,我深入学习和理解了操作系统的核心概念和原理。
在实际应用中,我更加清楚地认识到这些理论知识的重要性和应用场景。
2. 实践操作系统开发技能:在操作系统的开发和维护过程中,我学会了使用一些关键的操作系统开发工具和技术,如调试器、性能分析工具等。
这对我的职业发展将起到积极的促进作用。
3. 增强团队协作能力:在实习中,我和其他团队成员积极合作,并深入参与项目开发和讨论。
通过与其他成员的交流和合作,我不断提升了团队协作的能力和技巧。
五、实习心得这次操作系统实习经历让我受益匪浅。
通过亲身参与操作系统的开发和维护,我对操作系统的原理和实际应用有了更深入的理解。
同时,实习也增强了我的团队协作和解决问题的能力。
六、结语通过这次操作系统实习,我的实践能力和技术水平得到了很大提升。
华科操作系统实验报告一、实验目的操作系统是计算机系统的核心组成部分,对于理解计算机的工作原理和提高计算机应用能力具有重要意义。
本次华科操作系统实验的主要目的是通过实际操作和实践,深入理解操作系统的基本概念、原理和功能,掌握操作系统的核心技术和应用方法,提高我们的实践能力和问题解决能力。
二、实验环境本次实验使用的操作系统为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)三种内存分配算法。
操作系统实践报告引言:现代计算机已经成为人们生活和工作中不可或缺的一部分。
而计算机的核心就是操作系统。
操作系统是一种控制和管理计算机硬件和软件资源的软件系统。
操作系统为我们提供了方便的用户界面和高效的资源管理,使得计算机能够更加稳定和高效地运行。
本报告将重点介绍操作系统的实践,包括内存管理、文件系统、进程管理等方面的内容。
通过实践操作系统,我们将更好地理解和掌握计算机系统的工作原理。
一、内存管理内存管理是操作系统中最核心的部分之一。
在操作系统实践中,我们学习了常见的内存管理技术,如连续内存分配和非连续内存分配。
连续内存分配是将内存划分为若干连续的空闲区域,并根据进程的需要将其分配给进程。
而非连续内存分配则是将内存分为若干不连续的块,进程在运行时可以随时申请或释放内存。
通过实践内存管理,我们深入了解了进程的内存空间划分和管理方式,为进一步优化计算机系统性能提供了基础。
二、文件系统文件系统是操作系统中用于管理文件和目录的一种机制。
在实践操作系统中,我们学习了常见的文件系统类型,如FAT、NTFS等。
文件系统不仅负责文件和目录的创建、读写和删除,还需要处理文件的权限控制和数据的存储方式。
通过实践文件系统,我们掌握了文件系统的操作和管理技巧,提高了计算机系统的文件存储和访问效率。
三、进程管理进程管理是操作系统中最重要的功能之一。
在操作系统实践中,我们学习了进程的创建、调度和终止等操作。
进程是计算机系统中正在执行的程序的实例。
通过实践进程管理,我们深入了解了进程的运行机制和调度算法。
合理的进程管理能够提高计算机系统的并发性和响应速度,为用户提供更好的使用体验。
四、设备管理设备管理是操作系统管理计算机硬件设备的关键部分。
在操作系统实践中,我们学习了设备的分配、控制和回收等操作。
设备可以是计算机内部的硬件设备,如CPU、内存等,也可以是外部的设备,如打印机、鼠标等。
通过实践设备管理,我们熟悉了设备的初始化和驱动程序的安装,提高了计算机系统对硬件设备的控制和管理能力。
windows 操作实训报告概述本报告旨在全面呈现我在Windows操作实训课程中所学到的内容和实际操作经验。
通过这次实训,我掌握了Windows操作系统的基本功能、快捷键、文件管理、网络连接和故障排除等方面的知识和技能。
以下将从这些方面进行详细的介绍和讨论。
一、Windows操作系统的基本功能1. 桌面及任务栏在实训过程中,我学会了如何通过桌面的图标和任务栏快速访问应用程序和功能。
同时,了解了如何更改桌面背景和个性化设置,提升用户体验。
2. 文件资源管理器我学习了如何在Windows中使用文件资源管理器来管理文件和文件夹。
通过掌握拷贝、剪切、粘贴和删除文件以及文件夹的操作技巧,提高了管理文件的效率。
3. 控制面板通过实践,我了解了控制面板对于系统设置、硬件管理以及网络设置的重要性。
我学习了如何修改显示设置、更改默认程序、安装和卸载软件等基本操作。
二、Windows操作系统的快捷键1. 桌面和任务栏快捷键我熟练掌握了一些常用的桌面和任务栏快捷键,例如Win+D用于显示桌面,Win+Tab用于切换程序等。
通过使用这些快捷键,我能够更加高效地操作Windows系统。
2. 文件资源管理器快捷键通过学习文件资源管理器的快捷键,我可以更快速地进行文件管理操作,例如Ctrl+C、Ctrl+V用于复制和粘贴文件,Ctrl+X用于剪切文件等。
三、Windows操作系统的文件管理1. 文件和文件夹的操作在实训中,我学会了如何创建、修改和删除文件与文件夹。
掌握了文件重命名和属性设置的技巧,使我能够更好地进行文件的管理和整理。
2. 文件搜索与筛选通过使用Windows系统提供的搜索功能,我可以快速查找并定位到需要的文件。
同时,筛选功能也帮助我更好地分类和整理文件。
四、Windows操作系统的网络连接1. 无线网络连接设置实训中,我学习了如何在Windows系统中设置无线网络连接。
掌握了连接和断开无线网络的步骤,并学会了设置和修改无线网络的参数。
windows实践报告为了完成这篇关于Windows的实践报告,我将会涵盖以下主题:Windows的历史与背景,重要特性,主要组件,以及常见应用。
同时,我还将分享一些关于使用Windows的最佳实践和技巧。
希望你能在阅读的过程中学到更多有关于Windows操作系统的知识。
Windows的历史与背景Windows是一款由微软公司制造的操作系统,首次发布于1985年。
最初的版本是基于DOS操作系统的图形化用户界面,它迅速成为全球最为广泛使用的操作系统之一。
如今,Windows已经发展成为一个强大的操作系统平台,包括了丰富的应用程序和工具,跨足了计算机、电视、手机、平板电脑、游戏机等领域。
重要特性Windows的重要特性包括:多任务处理、虚拟内存、多用户支持、图形用户界面(GUI)、驱动程序以及支持各种硬件和软件。
这些特性使得Windows成为一个多用途、强大的操作系统,满足了各种不同用户的需求。
主要组件Windows由许多不同的组件组成,包括操作系统内核、网络和安全子系统、图形用户界面、应用程序、系统工具等。
其中最重要的组件是操作系统内核,它管理计算机的内存和进程,还负责与硬件和软件交互。
网络和安全子系统负责计算机网络的连接和安全性,图形用户界面则允许用户与计算机进行交互。
Windows的众多应用程序包括了办公套件、媒体播放器、游戏等等。
常见应用Windows是一个强大的操作系统,支持各种不同类型的应用程序和工具。
一些常见的Windows应用程序包括:1. Microsoft Office:包括Word、Excel和PowerPoint等应用程序。
2. Windows Media Player:用于播放音频和视频文件。
3. Internet Explorer和Microsoft Edge:用于浏览互联网。
4. Windows Defender:用于保护计算机免受恶意软件的攻击。
5. Windows应用商店:包括用于在Windows上运行的各种商业和免费的应用程序。
windows的实验报告(完整版)实验名称:Windows的实验报告实验目的:通过对Windows操作系统的学习和实践,了解并熟悉Windows操作系统的基本功能、操作方法及常用工具,提高计算机操作和应用能力。
实验要求:熟悉Windows操作系统的基本操作方法、文件管理及常用工具的使用。
实验设备:一台装有Windows操作系统的计算机。
实验步骤:1. Windows操作系统的启动与登录a. 按下计算机的电源按钮,等待计算机启动。
b. 在Windows登录界面输入正确的用户名和密码,点击登录。
2. Windows桌面的基本组成a. 熟悉桌面的各个元素,包括桌面图标、任务栏、开始菜单等。
b. 学习桌面图标的创建、删除、移动和重命名等操作。
3. 文件和文件夹管理a. 学习使用资源管理器打开文件和文件夹。
b. 创建新的文件夹,进行文件和文件夹的复制、剪切、粘贴和删除操作。
c. 学习使用搜索功能在计算机中查找文件和文件夹。
4. 常用工具的使用a. 学习使用文本编辑器编辑文本文件。
b. 学习使用画图工具创建简单的图形。
c. 了解并使用系统自带的计算器、记事本、画图、粘贴板等工具。
5. 网络连接与浏览器使用a. 熟悉网络连接的设置,连接到无线网络或有线网络。
b. 打开浏览器,访问常用的网站,搜索信息等。
6. Windows系统设置a. 了解并设置桌面背景、屏幕保护和分辨率等显示设置。
b. 了解并设置日期、时间和时区等时间设置。
c. 学习设置打印机和其他外部设备的配置。
7. 系统维护与安全a. 学习使用杀毒软件进行病毒扫描和清理。
b. 学习使用Windows自带的系统维护工具,如磁盘清理、磁盘碎片整理等。
8. 实验总结通过本次实验,我对Windows操作系统的基本功能和使用方法有了更深入的了解。
掌握了Windows桌面的基本组成,文件和文件夹的管理方法,以及常用工具的使用。
还学会了网络连接与浏览器的操作,Windows系统的基本设置,以及系统维护与安全等知识点。
《操作系统》实验二一、实验目的本实验旨在加深对操作系统基本概念和原理的理解,通过实际操作,提高对操作系统设计和实现的认知。
通过实验二,我们将重点掌握进程管理、线程调度、内存管理和文件系统的基本原理和实现方法。
二、实验内容1、进程管理a.实现进程创建、撤销、阻塞、唤醒等基本操作。
b.设计一个简单的进程调度算法,如轮转法或优先级调度法。
c.实现进程间的通信机制,如共享内存或消息队列。
2、线程调度a.实现线程的创建、撤销和调度。
b.实现一个简单的线程调度算法,如协同多任务(cooperative multitasking)。
3、内存管理a.设计一个简单的分页内存管理系统。
b.实现内存的分配和回收。
c.实现一个简单的内存保护机制。
4、文件系统a.设计一个简单的文件系统,包括文件的创建、读取、写入和删除。
b.实现文件的存储和检索。
c.实现文件的备份和恢复。
三、实验步骤1、进程管理a.首先,设计一个进程类,包含进程的基本属性(如进程ID、状态、优先级等)和操作方法(如创建、撤销、阻塞、唤醒等)。
b.然后,实现一个进程调度器,根据不同的调度算法对进程进行调度。
可以使用模拟的方法,不需要真实的硬件环境。
c.最后,实现进程间的通信机制,可以通过模拟共享内存或消息队列来实现。
2、线程调度a.首先,设计一个线程类,包含线程的基本属性(如线程ID、状态等)和操作方法(如创建、撤销等)。
b.然后,实现一个线程调度器,根据不同的调度算法对线程进行调度。
同样可以使用模拟的方法。
3、内存管理a.首先,设计一个内存页框类,包含页框的基本属性(如页框号、状态等)和操作方法(如分配、回收等)。
b.然后,实现一个内存管理器,根据不同的内存保护机制对内存进行保护。
可以使用模拟的方法。
4、文件系统a.首先,设计一个文件类,包含文件的基本属性(如文件名、大小等)和操作方法(如创建、读取、写入、删除等)。
b.然后,实现一个文件系统管理器,包括文件的存储和检索功能。
操作系统实验报告三存储器管理实验操作系统实验报告三:存储器管理实验一、实验目的本次存储器管理实验的主要目的是深入理解操作系统中存储器管理的基本原理和方法,通过实际操作和观察,掌握内存分配与回收的算法,以及页面置换算法的工作过程和性能特点,从而提高对操作系统资源管理的认识和实践能力。
二、实验环境本次实验使用的操作系统为 Windows 10,编程语言为 C++,开发工具为 Visual Studio 2019。
三、实验内容1、内存分配与回收算法实现首次适应算法(First Fit)最佳适应算法(Best Fit)最坏适应算法(Worst Fit)2、页面置换算法模拟先进先出页面置换算法(FIFO)最近最久未使用页面置换算法(LRU)时钟页面置换算法(Clock)四、实验原理1、内存分配与回收算法首次适应算法:从内存的起始位置开始,依次查找空闲分区,将第一个能够满足需求的空闲分区分配给进程。
最佳适应算法:在所有空闲分区中,选择能够满足需求且大小最小的空闲分区进行分配。
最坏适应算法:选择空闲分区中最大的分区进行分配。
2、页面置换算法先进先出页面置换算法:选择最早进入内存的页面进行置换。
最近最久未使用页面置换算法:选择最近最长时间未被访问的页面进行置换。
时钟页面置换算法:给每个页面设置一个访问位,在页面置换时,从指针指向的页面开始扫描,选择第一个访问位为0 的页面进行置换。
五、实验步骤1、内存分配与回收算法实现定义内存分区结构体,包括分区起始地址、大小、是否已分配等信息。
实现首次适应算法、最佳适应算法和最坏适应算法的函数。
编写测试程序,创建多个进程,并使用不同的算法为其分配内存,观察内存分配情况和空闲分区的变化。
2、页面置换算法模拟定义页面结构体,包括页面号、访问位等信息。
实现先进先出页面置换算法、最近最久未使用页面置换算法和时钟页面置换算法的函数。
编写测试程序,模拟页面的调入和调出过程,计算不同算法下的缺页率,比较算法的性能。
windows实践报告Windows操作系统是目前最广泛使用的个人电脑操作系统,它具备强大的功能和友好的用户界面,满足了人们在工作、学习和娱乐中的各种需求。
本篇报告将介绍我在使用Windows操作系统过程中的实践经验和心得,包括系统安装、应用软件的使用、网络连接和系统维护等方面。
一、系统安装在进行系统安装前,我首先检查了我的电脑硬件的兼容性。
确认硬件兼容后,我按照Windows官方提供的安装步骤,制作了启动盘并进入了安装界面。
安装界面提供了简洁明了的操作指导,我只需要按照步骤进行选择和设置即可完成系统的安装。
整个过程非常顺利,没有遇到任何问题。
二、应用软件的使用Windows操作系统提供了各种实用的应用软件,包括文字处理、表格制作、演示文稿、图片编辑等多种工具。
我经常使用的是Microsoft Office套件中的Word、Excel和PowerPoint,它们功能强大且界面简洁易于操作。
通过使用这些软件,我能够高效地完成文档编辑、数据分析和演示展示等工作。
此外,Windows操作系统还支持第三方应用软件的安装和使用,这大大提高了系统的可扩展性和适用性。
三、网络连接Windows操作系统提供了方便的网络连接功能,我只需要简单设置即可连接到有线或无线网络。
通过连接到互联网,我可以随时获取最新的信息,与他人保持联系,并完成在线学习和工作。
此外,Windows 操作系统还支持共享文件和打印机等网络资源,方便了多台电脑之间的文件传输和共享工作。
四、系统维护为了保持Windows操作系统的稳定和安全运行,我经常进行系统维护工作。
首先,我定期更新Windows操作系统和应用软件的补丁和版本,以获取系统的最新功能和安全性改进。
其次,我使用杀毒软件和防火墙保护系统免受病毒和恶意攻击。
最后,我清理系统垃圾文件、优化硬盘和进行定期的备份,以提高系统的性能和稳定性。
综上所述,Windows操作系统提供了强大的功能和便捷的界面,满足了我在工作、学习和娱乐中的各种需求。
第1篇实验名称:计算机基本操作与常用软件应用实验日期:2023年3月15日实验地点:计算机实验室实验目的:1. 掌握计算机的基本操作,包括开关机、文件管理、系统设置等。
2. 熟悉常用软件的使用,如文字处理软件、电子表格软件、演示文稿软件等。
3. 提高计算机应用能力,为后续课程学习打下基础。
实验内容:一、计算机基本操作1. 开关机操作(1)打开计算机,等待系统启动完成。
(2)使用鼠标点击屏幕左下角的“开始”按钮,选择“关机”选项。
(3)系统提示是否保存更改,根据实际情况选择保存或取消保存。
(4)点击“确定”按钮,等待计算机完全关闭。
2. 文件管理(1)打开文件资源管理器,了解文件结构。
(2)创建文件夹:点击“文件”菜单,选择“新建”->“文件夹”,输入文件夹名称,按“确定”按钮。
(3)重命名文件或文件夹:选中文件或文件夹,右击鼠标,选择“重命名”,输入新名称,按“Enter”键。
(4)删除文件或文件夹:选中文件或文件夹,右击鼠标,选择“删除”,在弹出的对话框中选择“是”。
3. 系统设置(1)打开“控制面板”,了解系统设置。
(2)调整屏幕分辨率:在“控制面板”中找到“显示”选项,调整分辨率。
(3)设置网络连接:在“控制面板”中找到“网络和共享中心”,设置网络连接。
二、常用软件应用1. 文字处理软件(Microsoft Word)(1)创建新文档:点击“开始”按钮,选择“所有程序”->“MicrosoftOffice”->“Microsoft Word”,打开Word软件。
(2)输入文字:在文档中输入文字,可以使用“格式”工具栏进行文字格式设置。
(3)保存文档:点击“文件”菜单,选择“保存”或“另存为”,设置保存路径和文件名,点击“保存”按钮。
2. 电子表格软件(Microsoft Excel)(1)创建新工作簿:点击“开始”按钮,选择“所有程序”->“Microsoft Office”->“Microsoft Excel”,打开Excel软件。
《计算机操作系统》课外实践报告一、实验目标:通过设计一个磁盘调度模拟系统,从而使磁盘调度算法更加形象化,容易使人理解,使磁盘调度的特点更简单明了,能使使用者加深对先来先服务算法、最短寻道时间优先算法、扫描算法以及循环扫描算法等磁盘调度算法的理解。
二、实验要求系统主界面可以灵活选择某种算法,算法包括:先来先服务算法(FCFS)、最短寻道时间优先算法(SSTF)、扫描算法(SCAN)、循环扫描算法(CSCAN)。
三.实践内容简要描述1、实践环境windows 2000/xp ,visual c 6.02、算法思路磁盘设备在工作时以恒定的速率旋转。
为了读或写,磁头必须能移动到所要求的磁道上,并等待所要求的扇区开始位置旋转到磁头下,然后或开始读或写数据。
故可把磁盘访问时间分成以下三部分。
(1)寻道时间Ts这是把磁头移动到指定磁道上所经历的时间。
该时间是启动磁臂的时间s与磁头移动n条磁道所花费的时间之和,即Ts=m*n+s其中,m是一常数,与磁盘驱动器的速度有关。
对于一般磁盘,m=0.2;对于高速磁盘,m<=0.1,磁臂的启动时间+约为2ms。
这样,对于一般的温盘,对于一般的温盘,其寻道时间将随着寻道距离的增加而增大,大体上是5~30ms。
(2)旋转延迟时间Tr这是指定扇区移动到磁头下面所经历的时间。
不同的磁盘类型中,旋转速度至少相差一个数量级,如软盘为300r/min,硬盘一般为7200~15000r/min,甚至更高。
对于磁盘旋转延迟时间而言,如硬盘,旋转速度为15000r/min,每转需时4ms,平均旋转延迟时间Tr为2ms;而软盘,其旋转速度为300r/min或600r/min,这样,平均Tr为50~100ms。
(3)传输时间Tt这时指把数据从磁盘读出或向磁盘写入数据所经历的时间。
Tt的大小与每次所读/写的字节数b和旋转速度有关:Tt=b/(r*N)其中,r为磁盘每秒钟的转数;N为一条磁道上的字节数,当一次读/写的字节数相当于半条磁道上的字节数时,T3与T2相同。
因此,可将访问时间Ta表示为Ta=Ts+1/(2*r)+b/(r*N)由上式可以看出,在访问时间中,寻道时间和旋转延迟时间基本上都与所读/写数据的多少无关,而且它通常占据了访问时间中的大头。
磁盘是可供多个进程共享的设备,当有多个进程都要求访问磁盘时,应采用一种最佳调度算法,以使各进程对磁盘的平均访问时间最小。
由于在访问磁盘的时间中,主要是寻道时间,因此,磁盘调度的目标是使磁盘的平均寻道时间最少。
现在我们考虑平均寻道长度:所有磁道所需移动距离之和除以总的所需访问的磁道数,所以寻道长度决定了寻道时间,我们需要从上面的算法中选择最优者。
3、算法原理磁盘驱动调度对磁盘的效率有重要影响。
磁盘驱动调度算法的好坏直接影响辅助存储器的效率,从而影响计算机系统的整体效率。
常用的磁盘驱动调度算法有:最简单的磁盘驱动调度算法是先入先出(FIFO)法:这种算法的实质是,总是严格按时间顺序对磁盘请求予以处理。
算法实现简单、易于理解并且相对公平,不会发生进程饿死现象。
但该算法可能会移动的柱面数较多并且会经常更换移动方向,效率有待提高。
最短寻找时间优先算法(SSTF):总是优先处理最靠近的请求。
该算法移动的柱面距离较小,但可能会经常改变移动方向,并且可能会发生进程饥饿现象。
电梯调度(SCAN):总是将一个方向上的请求全部处理完后,才改变方向继续处理其他请求。
循环扫描(CSCAN):从最外向最里(或从最里向最外)进行柱面请求处理,到最里柱面后,直接跳到最外柱面然后继续向里进行处理。
该算法与扫描算法的区别是,回来过程不处理请求,基于这样的事实,因为里端的请求刚被处理。
4、数据结构利用数组对算法进行处理。
now:当前磁道号cidao[],放置磁道号的数组void FCFS(int cidao[],int m),先来先服务算法void SSTF(int cidao[],int m),最短寻到时间优先算法void SCAN(int cidao[],int m),扫描算法void CSCAN(int cidao[],int m),循环扫描算法四、算法分析:(1)先来先服务算法(FCFS)这是一种最简单的磁盘调度算法。
它根据请求访问磁盘的先后次序进行调度。
此算法的优点是公平、简单,且每个进程的请求都能依次地得到处理,不会出现某一进程的请求长期得不到满足的情况。
但是此算法由于未对寻道进行优化,致使平均寻道时间可能较长。
当有进程先后提出磁盘I/O请求时,先按他们发出请求的先后次序排队。
然后依次给予服务。
其平均寻道距离较大,故先来先服务算法仅适用于请求磁盘I/O进程数目较少的场合。
(2)最短寻道时间优先算法(SSTF)该算法选择这样的进程:其要求访问的磁道与当前磁头所在的磁道距离最近,以使每次寻道时间最短。
但这种算法不能保证平均寻道时间最短。
有可能导致某个进程出现“饥饿”现象,因为只要不断有新进程请求到达,且其所要访问的磁道与磁头当前所在的磁道的距离较近,这种新进程的I/O请求必然优先满足。
(3)扫描算法(SCAN)该算法不仅考虑到正欲访问的磁道与当前磁道间的距离,更优先考虑的是磁头当前的移动方向。
例如,当磁头正在自里向外移动时,SCAN算法所考虑的下一个访问对象应该是其欲访问的磁道之外,又是距离最近的。
这样自里向外地访问,直至再无更外的磁道需要访问时,才将磁臂换向为自外向里移动。
这时,同样也是每次选择这样的进程来调度,既要访问的磁道在当前位置内距离最近者,这样,磁头又逐步地从外向里移动,直至再无更里面的磁道要访问,从而避免了出现“饥饿”现象。
由于在这种算法中磁头移动的规律颇似电梯的运行,因而又常称之为电梯调度算法。
(4)循环扫描算法(CSCAN)CSCAN算法规定磁头单向移动,例如,只是自里向外移动,当磁头移动到最外的磁道并访问后,磁头立即返回到最里的欲访问的磁道,亦即将最小磁道号紧接着最大的磁道号构成循环,进行循环扫描。
五、系统流程图FCFS算法(先来先服务)流程图:输入当前磁道号now磁头移动距离sum=abs(now-cidao[0]磁头移动总距离sum+=abs(cidao[j]-cidao[i]输出磁盘调度序列cidao [j]目前的位置变为当前的位置j++j<m输出平均寻道长度ave=sum/(m)SSTF (最短寻道时间优先算法) 算法流程图:将磁道号从小到大排序输入当前磁道号nowcidao[m-1]<=now输出磁盘调度序列cidao[j]目前的位置变为当前的位置now=cidao[i]磁头移动总距离sum=now-cidao[i]i>=0输出磁盘调度序列cidao[j](cidao[0]>=now磁头移动总距离sum=now-cidao[i]目前的位置变为当前的位置now=cidao[i]i<m确定当前磁道在已排的序列中的位置now-cidao[l])<=(cidao[r]-now先向磁道号减小方向访问,再向磁道号增加方向输出磁盘调度序列先向磁道号增加方向访问,再向磁道号减小方向输出磁盘调度序列输出平均寻道长度ave=sum/(m)SCAN 算法(扫描算法)流程图:源代码#include<stdio.h> #include<stdlib.h> #include<iostream.h> #include<math.h> #define maxsize 1000/*********************判断输入数据是否有效**************************/ int decide(char str[]) //判断输入数据是否有效 {将磁道号从小到大排序输入当前磁道号now, 移动臂的移动的方向cidao[m-1]<=now磁头移动总距离sum=now-cidao[i]输出磁盘调度序列cidao[j]i>=0(cidao[0]>=now输出磁盘调度序列cidao[j]i<m 磁头移动总距离sum=cidao [i]-now确定当前磁道在已排的序列中的位置switch(dcase 0:移动臂向磁道号减小方向访问case 1:移动臂向磁道号增加方向访问输出磁盘调度序列输出磁盘调度序列输出平均寻道长度ave=sum/(m)int i=0;while(str[i]!='\0'){if(str[i]<'0'||str[i]>'9'){return 0;break;}i++;}return i;}/******************将字符串转换成数字***********************/ int trans(char str[],int a) //将字符串转换成数字{int i;int sum=0;for(i=0;i<a;i++){sum=sum+(int)((str[i]-'0')*pow(10,a-i-1));}return sum;}/*********************冒泡排序算法**************************/ int *bubble(int cidao[],int m){int i,j;int temp;for(i=0;i<m;i++) //使用冒泡法按从小到大顺序排列for(j=i+1;j<m;j++){if(cidao[i]>cidao[j]){temp=cidao[i];cidao[i]=cidao[j];cidao[j]=temp;}}cout<<"排序后的磁盘序列为:";for( i=0;i<m;i++) //输出排序结果{cout<<cidao[i]<<" ";}cout<<endl;return cidao;}/*********************先来先服务调度算法************************/ void FCFS(int cidao[],int m) //磁道号数组,个数为m{int now;//当前磁道号int sum=0; //总寻道长度int j,i;int a;char str[100];float ave; //平均寻道长度cout<<"磁盘请求序列为:";for( i=0;i<m;i++) //按先来先服务的策略输出磁盘请求序列{cout<<cidao[i]<<" ";}cout<<endl;cout<<"请输入当前的磁道号:";B: cin>>str; //对输入数据进行有效性判断a=decide(str);if(a==0){cout<<"输入数据的类型错误,请重新输入!"<<endl;goto B;}elsenow=trans(str,a); //输入当前磁道号sum+=abs(cidao[0]-now);cout<<"磁盘扫描序列为:";for( i=0;i<m;i++) //输出磁盘扫描序列{cout<<cidao[i]<<" ";}for(i=0,j=1;j<m;i++,j++) //求平均寻道长度{sum+=abs(cidao[j]-cidao[i]);ave=(float)(sum)/(float)(m);}cout<<endl;cout<<"平均寻道长度:"<<ave<<endl;}/**********************最短寻道时间优先调度算法********************/ void SSTF(int cidao[],int m){int now,l,r;int i,j,sum=0;int a;char str[100];float ave;cidao=bubble(cidao,m); //调用冒泡排序算法排序cout<<"请输入当前的磁道号:";C: cin>>str; //对输入数据进行有效性判断a=decide(str);if(a==0){cout<<"输入数据的类型错误,请重新输入!"<<endl;goto C;}elsenow=trans(str,a); //输入当前磁道号if(cidao[m-1]<=now) //若当前磁道号大于请求序列中最大者,则直接由外向内依次给予各请求服务{cout<<"磁盘扫描序列为:";for(i=m-1;i>=0;i--)cout<<cidao[i]<<" ";sum=now-cidao[0];}if(cidao[0]>=now) //若当前磁道号小于请求序列中最小者,则直接由内向外依次给予各请求服务{cout<<"磁盘扫描序列为:";for(i=0;i<m;i++)cout<<cidao[i]<<" ";sum=cidao[m-1]-now;}if(now>cidao[0]&&now<cidao[m-1]) //若当前磁道号大于请求序列中最小者且小于最大者{cout<<"磁盘扫描序列为:";while(cidao[k]<now) //确定当前磁道在已排的序列中的位置,后面的算法都用到了,可以直接复制后少量修改,节省时间。