Nachos操作系统实验二:具有优先级的线程调度

注意

所有单独修改部分均在其后方注释add here
整体修改部分均在其上下注释add here
实验提供的makefile文件应该是支持在原代码上直接修改的,所以如果要移动代码到新的文件夹,请自行修改makefile文件。

实验目的

1.熟悉Nachos原有的线程调度策略;
2.设计并实现具有静态优先级的非抢占式线程调度策略。

实验思路

实验要求实现具有静态优先级的非抢占式线程调度策略,首先找到线程调度的相关位置,为code/threads/scheduler类。ReadyToRun(),用于将线程放入就绪队列;FindNextToRun(),用于选择下一个运行的进程;Run()用于将进程运行。选择其中的一个修改来实现线程调度,我采用ReadyToRun()来实现线程调度。

实验过程

1.要先有优先级才能实现按照优先级的调度,所以先设置优先级。

(1)在thread.h中,在private修饰符后添加int priority存储优先级,然后在public修饰符后添加int getPriority()获取优先级。同时由于老师要求的测试样例,所以增加一种构造方法,即public修饰符后面的Thread(const…,int priority),至此thread.h文件修改完毕,无需多余处理。
修改情况:在这里插入图片描述
(2)在thread.cc中做同步修改,给出方法的具体实现。由此实现了优先级的大部分修改(在结果输出中还要打印一下优先级,后面会说)。thread.cc处理完毕,无需多余修改。
修改情况:
在这里插入图片描述在这里插入图片描述在这里插入图片描述

2.获得优先级后即可开始控制调度,此处在scheduler.cc中修改ReadyToRun()方法控制调度。由此调度相关全部完成。

修改情况:

在这里插入图片描述

3.按照README中的要求修改threadtest.cc中的ThreadTest()方法,同时为了和答案保持一致,对threadtest.cc中的SimpleThread(_int which)方法做出一定修改。至此全部修改完毕。

修改情况:

在这里插入图片描述在这里插入图片描述

4.进行编译,查看结果。

结果:
在这里插入图片描述

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值