操作系统作业调度算法c语言,操作系统课程设计报告电梯调度算法c语言实现.doc...

操作系统课程设计报告电梯调度算法c语言实现

操作系统课程设计报告电梯调度算法c语言实现

:调度 算法 电梯 课程设计 操作系统 操作系统课程设计报告 模拟操作系统课程设计 写一个简单的操作系统

篇一:操作系统磁盘调度算法课程设计报告及代码

淮阴工学院

操作系统课程设计报告

选题名称: 磁盘调度算法的模拟实现 系(院): 经济管理学院专 业: 信息管理与信息系统 班 级: 姓 名: 学 号: 指导教师:

学年学期:学年 第学期年月日

设计任务书

指导教师(签章):

年月

摘要:

磁盘是外设中一个很常用的部分,所以,对磁盘数据的寻道时间的长短可以直接影响机器的整体运行速度的快慢。本设计为一个模拟磁盘调度算法的磁盘调度模拟系统,能够模拟先来先服务(FCFS)算法、最短寻道时间(SSTF)算法、电梯(SCAN)算法、环形扫描(C_SCAN)算法及N_SCAN算法五个磁盘调度算法,输入为一组作业的磁道请求,输出为按选择的算法执行时的磁头移动轨迹。其中,先来先服务(FCFS)算法、最短寻道时间(SSTF)算法、电梯(SCAN)算法为基本算法,环形扫描(C_SCAN)算法及N_SCAN算法为扩展算法。

关键字:磁盘调度;模拟;算法;选择;执行;

目录

1 磁盘调度算法的基本概念 ................................................................................ 1

2 主要算法分析 ................................................................................................... 2

2.1 先来先服务算法(FCFS) .................................................................................. 2

2.2 最短寻道时间优先算法(SSTF) ...................................................................... 2

2.3 扫描算法(SCAN) ............................................................................................ 2

3 各算法的流程图 ............................................................................................... 3

4 调试分析及测试结果 ..................................................................................... 5

4.1 运行结果 ............................................................................................................. 5

4.2 程序代码 ............................................................................................................ 7

总 结 ................................................................................................................. 12

致 谢 ................................................................................................................. 13

参考文献 ............................................................................................................. 14

1 磁盘调度算法的基本概念

设备的动态分配算法与进程调度相似,也是基于一定的分配策略的。常用的分配策略有先请求先分配、优先级高者先分配等策略。在多道程序系统中,低效率通常是由于磁盘类旋转设备使用不当造成的。操作系统中,对磁盘的访问要求来自多方面,常常

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
很抱歉,作为AI,我没有能力提供实验报告。但是我可以为您提供一些关于时间片轮转调度算法的基本信息和C语言实现的思路。 时间片轮转调度算法是一种常用的进程调度算法,它将CPU时间分成若干个时间片,每个进程在一个时间片内获得相同数量的CPU时间,如果进程在时间片结束之前没有执行完,则将其放入就绪队列的末尾,等待下一次执行。这样可以保证每个进程都有机会获得CPU时间,避免进程长时间占用CPU的情况,提高系统的资源利用率。 在C语言中,我们可以使用结构体来表示进程的信息,包括进程ID、进程状态、执行时间和优先级等。我们可以使用一个数组来存储所有进程的信息,并使用一个循环队列来表示就绪队列,每个时间片从队首开始执行,执行完毕后将进程放到队列尾部,直到所有进程都执行完毕。 以下是时间片轮转调度算法C语言实现参考代码: ``` #include <stdio.h> #define MAX_PROCESS_NUM 10 #define TIME_SLICE 2 struct Process { int pid; // 进程ID int status; // 进程状态,0表示未执行,1表示正在执行,2表示已完成 int priority; // 进程优先级 int execute_time; // 进程执行时间 }; int main() { struct Process processes[MAX_PROCESS_NUM]; int ready_queue[MAX_PROCESS_NUM]; int head = 0, tail = 0; int process_num, current_time = 0; int i, j; printf("请输入进程数:"); scanf("%d", &process_num); // 初始化进程信息 for (i = 0; i < process_num; i++) { printf("请输入进程%d的信息(ID 优先级 执行时间):", i + 1); scanf("%d%d%d", &processes[i].pid, &processes[i].priority, &processes[i].execute_time); processes[i].status = 0; // 所有进程初始状态均为未执行 } // 将所有进程放入就绪队列 for (i = 0; i < process_num; i++) { ready_queue[tail++] = i; } // 时间片轮转调度 while (head != tail) { // 就绪队列不为空 int current_process = ready_queue[head]; head = (head + 1) % MAX_PROCESS_NUM; // 队首出队 if (processes[current_process].execute_time > TIME_SLICE) { // 执行一个时间片 current_time += TIME_SLICE; processes[current_process].execute_time -= TIME_SLICE; // 将进程重新放入就绪队列末尾 ready_queue[tail] = current_process; tail = (tail + 1) % MAX_PROCESS_NUM; } else { // 执行剩余时间 current_time += processes[current_process].execute_time; processes[current_process].execute_time = 0; processes[current_process].status = 2; // 进程执行完毕 // 输出进程执行信息 printf("进程%d执行完毕,执行时间:%d,优先级:%d\n", processes[current_process].pid, current_time, processes[current_process].priority); // 将已完成进程从就绪队列中删除 for (i = 0; i < tail; i++) { if (ready_queue[i] == current_process) { for (j = i; j < tail - 1; j++) { ready_queue[j] = ready_queue[j + 1]; } tail--; break; } } } } return 0; } ``` 以上代码仅供参考,具体实现方式可以根据实际情况进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值