- 1、本文档共5页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
(进程调度)
福州大学应用技术与继续教育学院
《操作系统原理》上机实验报告
专业和班级 计算机科学与技术 成绩 姓名 郑艺鹏 学号 261180579 课程名称 操作系统原理 实验名称 进程调度 实
验
目
的
和
要
求 理解和掌握有关进程、进程控制块、进程同步等基本知识。
进程调度是处理机管理的核心内容。理解几种常用的进程调度算法的原理和特性。
通过编程实现常用的进程调度,学习先进先出、优先数、时间片轮转、多级反馈队列等调度算法的一种或几种具体实施办法。
理
论
基
础 什么是进程,其特点和组成各是什么。
答;进程:程序在一次数据集合上的一次执行过程。
特点:动态性、并发性、独立性、异步性。
组成:程序段、数据段、进程控制块三部分构成了进程实体
简述4种常用的进程调度算法的基本内容。
答:先来先服务是按照进入就绪队列的先后次序来分配处理机。FCFS采用非剥夺调度方式,即一旦某个进程占有处理机,就一直运行下去,直到该进程完成其工作或因等待某一事件而不能继续执行时才释放处理机。每个进程被分配一个时间段,称作它的时间片,即该进程允许运行的时间。如果在时间片结束时进程还在运行,则CPU将被剥夺并分配给另一个进程。如果进程在时间片结束前阻塞或结束,则CPU当即进行切换。调度程序所要做的就是维护一张就绪进程列表,当进程用完它的时间片后,它被移到队列的末尾。package com.pp;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
public class PR {
@SuppressWarnings(unchecked)
public static void main(String[] str) {
ListTask list = new ArrayListTask();
Task task2 = new Task(C, 56, 5, 0);
Task task3 = new Task(D, 76, 2, 0);
Task task4 = new Task(E, 45, 4, 0);
Task task = new Task(A, 66, 8, 0);
Task task1 = new Task(B, 65, 3, 0);
list.add(task);
list.add(task1);
list.add(task2);
list.add(task3);
list.add(task4);
Collections.sort(list, new Task());
Priority priority = new Priority(list);
priority.run();
}
}
class Priority {
private ListTask list;
private int round;
private int currentTime;
public Priority(ListTask list) {
this.list = list;
round = 4;
currentTime = 0;
}
@SuppressWarnings(unchecked)
public void run() {
int index = 0;
int time = 0;
System.out.println(进程名称 完成时间 优先数);
while (list != null list.size() 0) {
if (time 0) {
round -= time;
} else {
round = 4;
}
time = list.get(index).getServeTime() - round;
list.get(index).setPriority(list.get(index).getPriority() - 3);
for (int i = index + 1; i list.size(); i++) {
list.get(i).setPriority(list.get(i).getPriority() + 1);
}
i
您可能关注的文档
- 2011届土木工程专业道桥方向.doc
- 2011年6月份用车记录.doc
- 高考冲刺的策略与问题解疑课件(人教版).ppt
- 设计-09-1.ppt
- 2012年上海市普通高中学业水平考试物理试卷(含标准答案与评分标准).doc
- 2006~2007游标卡尺使用.ppt
- 4.1消防燃烧学.ppt
- LINUXC编程(第四讲).ppt
- c语言教学ppt第7章.ppt
- 9∏型架空刚性接触网技术研究.ppt
- 数据仓库:Redshift:Redshift与BI工具集成.docx
- 数据仓库:Redshift:数据仓库原理与设计.docx
- 数据仓库:Snowflake:数据仓库成本控制与Snowflake定价策略.docx
- 大数据基础:大数据概述:大数据处理框架MapReduce.docx
- 实时计算:GoogleDataflow服务架构解析.docx
- 分布式存储系统:HDFS与MapReduce集成教程.docx
- 实时计算:Azure Stream Analytics:数据流窗口与聚合操作.docx
- 实时计算:Kafka Streams:Kafka Streams架构与原理.docx
- 实时计算:Kafka Streams:Kafka Streams连接器开发与使用.docx
- 数据仓库:BigQuery:BigQuery数据分区与索引优化.docx
文档评论(0)