- 2
- 0
- 约9.01千字
- 约 25页
- 2017-08-20 发布于浙江
- 举报
Java模拟操作系统进的程优先级调度
//进程块
/**
*
* ① 设计PCB及其数据结构: 进程标识数:ID 进程优先数:PRIORITY(优先数越大,优先级越高)
* 进程已占用时间片:CPUTIME,每得到一次调度,值加1;
* 进程还需占用时间片:ALLTIME,每得到一次调度,该值减1,一旦运行完毕,ALLTIME为0) 进程队列指针:NEXT,用来将PCB排成队列
* 进程状态:STATE(一般为就绪,可以不用) ② 设计进程就绪队列及数据结构; ③ 设计进程调度算法,并画出程序流程图; ④ 设计输入数据和输出格式;
* 结构格式:当前正运行的进程:0 当前就绪队列:2,1,3,4 ⑤ 编程上机,验证结果
*
*
*/
public class PCB {
private int id;
private int priority;
private int cpuTime;
private int allTime;
private int state;// 状态为1的时候表示准备就绪
/**
* 无参数的构造方法,通过geter,seter器来对PCB的信息进行获取的修改
*/
public PCB() {
}
/**
* 初始化PCB的基本信息的构造方法
*
* @param id
* @param priority
* @param cpuTime
* @param allTime
* @param state
*/
public PCB(int id, int priority, int cpuTime, int allTime, int state) {
super();
this.id = id;
this.priority = priority;
this.cpuTime = cpuTime;
this.allTime = allTime;
this.state = state;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public int getPriority() {
return priority;
}
public void setPriority(int priority) {
this.priority = priority;
}
/**
* 根据要求来修改PCB的优先级
*/
public void modifyPriority() {
if (0 this.priority) {
this.priority -= 3;
}
return;
}
public int getCpuTime() {
return cpuTime;
}
public void setCpuTime(int cpuTime) {
this.cpuTime = cpuTime;
}
/**
* 根据要求修改CPU时间
*/
public void modifyCpuTime() {
this.cpuTime += 1;
}
public int getAllTime() {
return allTime;
}
public void setAllTime(int allTime) {
this.allTime = allTime;
}
/**
* 根据要求修改PCB占用的时间片
*/
public void modifyAllTime() {
if (0 this.allTime) {
this.allTime -= 1;
}
return;
}
public int getState() {
return state;
}
public void setState(int state) {
this.state = state;
}
/**
* 根据要求修改PCB的状态
*/
public void midifyState() {
}
/**
* 打印显示当前PCB的全部信息
*/
public void showStatus() {
System.out.println(PCB [id= + id + , priority= + priority
+ , cpuTime= + cpuTime + , allTime= + allTime + , state=
+ state + ]);
}
/**
* 修
原创力文档

文档评论(0)