《Operating Systems:Three Easy Pieces》第八章课后习题解答

8.1

1.只用两个工作和两个队列运行几个随机生成的问题。针对每个工作计算 MLFQ 的执行记录。限制每项作业的长度并关闭 I/O,让你的生活更轻松。
在这里插入图片描述
答:python3 mlfq.py -n 2 -j 2 -m 15 -M 0 -s 50参数设置-n 2代表2个队列,-j 2 代表2个作业,-m 15 表示随机生成的作业最大运行时间为15,-M 0 表示随机生成的作业最大I/O频率为0,即关闭I/O,-s 20 设置随机种子为50。最后随机生成的情况为每队列时间片为10,Job 0: startTime 0 - runTime 7 - ioFreq 0,Job 1: startTime 0 –runtime 9 -ioFreq 0。
计算MLFQ执行记录如下:
Time Job Queue The situation of CPU
0 0 1 作业0、1到达,运行作业0的1时间单位
1 0 1 运行作业0的1时间单位
2 0 1 运行作业0的1时间单位
3 0 1 运行作业0的1时间单位
4 0 1 运行作业0的1时间单位
5 0 1 运行作业0的1时间单位
6 0 1 运行作业0的1时间单位
7 1 1 作业0完成,运行作业1的1时间单位
8 1 1 运行作业1的1时间单位
9 1 1 运行作业1的1时间单位
10 1 1 运行作业1的1时间单位
11 1 1 运行作业1的1时间单位
12 1 1 运行作业1的1时间单位
13 1 1 运行作业1的1时间单位
14 1 1 运行作业1的1时间单位
15 1 1 运行作业1的1时间单位
16 - - 作业1完成

Job Response Turnaround Wait
0 0 7 0
1 7 16 7
average 3.50 11.50 3.50
在这里插入图片描述

PS:不知道是不是理解出现了偏差,无论如何-a修改MLFQ的时间配额allotments,作业确实是按时间片进行轮转,但是不会按照配额降低优先级???

8.3

3.将如何配置调度程序参数,像轮转调度程序那样工作?
答:RR调度是依据时间片进行轮转的,而且需要作业数>=2,不会发生优先级降低,所以只能有一个队列。于是:
python3 mlfq.py -n c1 -j c2 -q c3 (参数:c1=1,c2>=2,c3为时间片长度)

8.5

5.给定一个系统,其最高队列中的时间片长度为 10ms,你需要如何频繁地将工作推回到高优先级级别(带有-B 标志),以保证一个长时间运行(并可能饥饿)的工作得到至少5%的 CPU?
答:发生“饥饿”的原因是MLFQ的规则当一个作业在其时间片内主动放弃CPU,那么它的优先级不变。这样当有很多交互程序时,每个交互程序运行一段时间后(不足一个时间片)主动放弃CPU发起I/O,I/O持续时间内另一个作业刚好也运行不足一个时间片,随后当第一个作业完成I/O时第二个作业发出I/O,两个作业的优先级都不会降低且一直切换霸占CPU导致其他作业被“饿死”。所以需要每隔一段时间boost提升所有作业到最高优先级队列。此时长时间运行作业可以占用CPU一个时间片,随后降低优先级,继续“饥饿”直到下一次boost又占用CPU一个时间片。若最高队列时间片长度为10ms,切要保证一个长时间运行作业得到至少5%的CPU,那么在一个boost时间内它就要获得5%的CPU,这个时间也是一个时间片长度,所以
T(boost) = T(time slice) / 0.05 = 10 / 0.05 = 200 ms。综上,将作业推回到最高优先级的时间频率不能大于200 ms。

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: "Operating Systems: Three Easy Pieces"(操作系统:三步轻松学)是一本由Remzi H. Arpaci-Dusseau和Andrea C. Arpaci-Dusseau编写的计算机科学教材。本书旨在介绍操作系统背后的核心原理和概念,以及其在计算机系统中的作用。 该书的内容涵盖了操作系统的多个方面,包括进程管理、内存管理、文件系统、输入输出、虚拟化、并发与并行等。它提供了广泛的范围,旨在帮助读者全面了解操作系统的基本概念和内部工作原理。 该书的第一部分介绍了操作系统的基本概念,例如进程、线程和调度算法。它解释了多任务处理的基本原理,并讨论了与并发性和并行性相关的问题。 第二部分讨论了内存管理和虚拟化技术,包括分页、分段、内存分配和页面置换等。它还讨论了操作系统如何处理死锁和内存泄漏等问题。 第三部分则专注于文件系统和存储技术。它解释了文件系统的层次结构和存储管理,以及如何实现文件和目录的访问控制和保护机制。 总的来说,《操作系统:三步轻松学》这本书以易于理解和深入浅出的方式,介绍了操作系统的关键概念和原理。它旨在帮助读者建立对操作系统的基本了解,以及如何设计和实现一个高效稳定的操作系统。无论是计算机科学专业的学生、软件开发人员还是系统管理员,都可以从这本书中获得宝贵的知识和见解,以提升对操作系统理解和应用能力。 ### 回答2: 《操作系统:三个简单的组成部分》是一本关于操作系统的英文书籍。该书由Remzi H. Arpaci-Dusseau和Andrea C. Arpaci-Dusseau合著。这本书旨在以简洁易懂的方式介绍操作系统的基本概念和原理。 书中主要涵盖操作系统的三个组成部分,即虚拟化、并发性和持久性。虚拟化是指操作系统利用物理资源来创建多个虚拟资源的能力,例如虚拟内存,使得多个程序可以在同一台机器上同时运行。并发性涉及操作系统如何管理和调度同时运行的多个任务。持久性是指操作系统如何管理和访问长期存储,例如硬盘或闪存。 书中通过详细的示例和清晰的解释,阐述了各种操作系统的基本概念和常见问题的解决方案。它还介绍了操作系统的设计原则和优化技术,以及一些常见的操作系统功能,如进程管理、内存管理和文件系统。 这本书是为初学者和其他对操作系统感兴趣的人编写的,而且不需要太多的预备知识。它的目标是帮助读者理解操作系统的基本原理和如何实现它们。 总之,《操作系统:三个简单的组成部分》是一本很好的操作系统入门书籍,它以易读易懂的方式介绍了操作系统的基本概念和原理。无论是对于学生、软件工程师还是对操作系统感兴趣的人来说,这本书都会提供有价值的知识和见解。 ### 回答3: 《操作系统:三部简单的作品》是一本关于操作系统的英文书籍。这本书由Remzi H. Arpaci-Dusseau和Andrea C. Arpaci-Dusseau撰写,旨在介绍操作系统的基本原理和概念。 该书主要分为三个部分,每个部分都涵盖一个关键主题。第一部分介绍了操作系统的概述和基本概念,包括进程、线程、调度、同步和死锁等。它通过一系列易懂的例子和实验帮助读者理解这些概念,并展示它们在实际操作系统中的应用。 第二部分深入讨论了操作系统的内存管理和虚拟内存的原理。它解释了内存分配、地址转换和页面置换等重要的内存管理技术,以及虚拟内存的概念和工作原理。读者可以通过实践性的编程练习来巩固所学知识。 最后一部分探讨了文件系统和存储技术。它介绍了文件系统的组织和功能,包括文件的访问权限、目录结构和磁盘调度算法。此外,它还讨论了存储技术的发展,例如RAID和闪存。 《操作系统:三部简单的作品》以其简洁明了的风格和通俗易懂的示例而闻名。它适用于那些对操作系统感兴趣的初学者和教育者。读者无需具备深厚的计算机科学背景,即可轻松理解书中的内容。 总之,这本书是一本介绍操作系统基本原理和概念的优秀教材。通过阅读《操作系统:三部简单的作品》,读者可以建立起对操作系统的深入理解,从而在实践中更好地应用和开发操作系统

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值