操作系统精选题(四)(论述题)

news2025/1/15 6:39:50

🌈 个人主页:十二月的猫-CSDN博客
🔥 系列专栏: 🏀操作系统

💪🏻 十二月的寒冬阻挡不了春天的脚步,十二点的黑夜遮蔽不住黎明的曙光 

目录

前言

一、银行家算法的一道例题

二、页大小为 1024 字节,计算逻辑地址 2560 和 4220 对应的物理地址

三、 页计算问题

四、进程同步问题

六、单级页表;TLB 命中率为 90%,访问 TLB 需 5ns,访问主存为 25ns,求有效内存的访问时间

七、请求分页系统中,页表项中包含哪些数据项?它们的作用?

八、画出分页内存管理方案的过程图,描述流程、过程中硬件或软件所起的作用。

九、分页式文件系统的主要数据结构,要使用这个分页结构需要哪些硬件支持

十、当前页表如下。页大小为1024字节,该程序分配2个帧,页号0先装入内存。采用先进先出和局部置换策略,现在访问逻辑地址为3000的字节,问在这个过程中发生了什么主要事件并写出 置换后的页表。

十一、比对FIFO算法和LRU算法

十二、增强的二次机会算法的基本思想;为什么会发生抖动,怎么解决?

十三、三种磁盘空间分配方法(contiguous、linked、indexed)的优缺点

十四、基于磁盘的分配方法,设计一种高效的磁盘空闲空间分配和回收方法,说出基本思想,操作过程和数据结构。

十五、某磁盘文件区16GB,每个磁盘块为1KB,

(1)若空闲存储空间采用位图管理方法那么位图需占用多少个盘块

(2)若采用FAT,FAT中每个盘块地址用4字节表示,问FAT表需要几个盘块

十六、某文件系统为一级目录,文件的数据一次性写入磁盘,已经写入的文件不可修改,但可以多次创建新文件,请回答:

十七、假如盘块的大小为4KB,每个盘块号占4个字节,在两级索引分配时,允许的最大文件是多少?(请写出计算过程)

十八、简要描述操作系统中打开文件的工作过程(等价于 如何通过文件名找到文件)

十九、三种磁盘空间分配方法(连续、链接、索引)FCB中的描述字段

二十、非阻塞和阻塞I/O是什么,主要有什么不同,分别用在哪里?

总结


前言

本系列题目均选自山东大学往年考题,供大家复习参考。一定要在复习完基础知识后(最好把书本都看一遍,这样子知识体系才是完善的),再来参考这个练习题。

两个不可取:一、不可不复习知识点,光做题;二、不可只复习知识点,不复习

猫猫祝大家都能取得好成绩呀~~~

一、银行家算法的一道例题

 题目解答:

二、页大小为 1024 字节,计算逻辑地址 2560 和 4220 对应的物理地址

 2560的物理地址:

  1. 2560/1024=2.几,因此在第三页即页号为2的页,同时页内偏移为:2560-2048=512
  2. 对应块号为60。分页算法中内存中的每一块对应就是一页。所以物理地址为:60*1024+512=61952

 4220的物理地址:

  1. 4220=1024*4+124
  2. 因为在第五页,而进程页表中只有四页,所以这是越界访问,逻辑地址4220是非法的

三、 页计算问题

2560=1024*2+512

4098=1024*4+2

18*1024+512=18944

页号4越界,逻辑地址4098非法

四、进程同步问题

//确定进程类别:只有一种类别的进程,这种进程有三个
//确定主营业务:过桥、在白板上更新物资200个(不用dowhile循环)
//找同步约束:互斥、资源、限额(这里是资源里的进程执行顺序限制)
int wuzi_num=0;//白板,临界区
semaphore mutex=1;//临界区互斥变量
semaphore liang=0;//让小亮启动的同步信号量
semaphore ming=0;//让小明启动的同步信号量
xiaohua{
    /*过桥*/
    signal(liang);
    wait(mutex);
    wuzi_num+=200;
    signal(mutex);
}
xiaoming{
    wait(ming)
    /*过桥*/
    wait(mutex)
    wuzi_num+=200;
    signal(mutex);
}
xiaoliang{
    wait(liang);
    /*过桥*/
    signal(ming)
    wait(mutex)
    wuzi_num+=200;
    signal(mutex);
}

六、单级页表;TLB 命中率为 90%,访问 TLB 需 5ns,访问主存为 25ns,求有效内存的访问时间

一、页表存放在内存中,所以如果通过页表访问内存,需要访问主存两次

二、如果通过TLB访问内存,则通过TLB能找到数据在主存中的位置,所以访问主存一次

0.9*(5+25)+0.1*(5+25+25)=32.5ns

七、在某个分页管理系统中,某一个作业有 4 个页面,被分别装入到主存的第 3、4、6、8 块中,假定页面和块大小均为 1024 字节,当作业在 CPU 上运行时,执行到其地址空间第 500 号处遇到 一条传送命令: MOV 2100,3100 画地址转换图计算出 MOV 指令中两个操作数的物理地址

1、作业=进程

2、内存中的块和页都是从0开始算的

2100=1024*2+52

3100=1024*3+28

2100对应第三页,页内偏移为52;3100对应第四页,页内偏移为28

2100物理地址为:6*1024+52=6196

3100物理地址为:8*1024+28=8220

七、请求分页系统中,页表项中包含哪些数据项?它们的作用?

页表项中包含:页号(隐含)、帧号、保护位、修改位、访问位

保护位:也叫有效/无效位,记录该页是否是有效的。无效位包括缺页和其他情况。

访问位:用来判断该页在一段时间内被访问的次数,或者多长时间未访问(不同页面置换算法不同),通过这一位页面置换算法可以确定置换哪一页

修改位:判断该页是否被修改过。通过修改页能够在该页被置换出来后判断要不要写入磁盘

帧号:记录对应页号在物理内存中的那一块

八、画出分页内存管理方案的过程图,描述流程、过程中硬件或软件所起的作用。

分页内存管理方案=分页内存创建与维护方案+分页内存使用方案

分页内存创建与维护方案流程:

  • 页面创建:创建进程时,操作系统为该进程创建一个页表,这个页表大小取决于该进程有多少页,而多少页又取决于进程地址空间大小以及页面大小。同时操作系统要对页表进行初始化
  • 页面维护:在虚拟内存中,如果发生缺页就会陷入内核。操作系统就要更新页表,同时更新页表时可能也涉及到页面置换等操作

分页内存使用方案流程:

  • 应用程序提供逻辑地址
  • MMU接受应用程序提供的地址,计算得到页号,页内偏移等
  • MMU查找页表,获取页表项
  • MMU根据页表项中的帧号和页内偏移计算得到逻辑地址对应的物理地址

硬件作用:里面发挥作用的硬件就是MMU。MMU起到查询页表项、根据逻辑地址计算物理地址等作用

软件作用:里面发挥作用的软件就是操作系统。操作系统在里面发挥创建维护页表、更新页表等作用

九、分页式文件系统的主要数据结构,要使用这个分页结构需要哪些硬件支持

分页式文件系统和分页式内存管理系统是类似的

其所用的数据结构、硬件支持也是一样的

分页式系统的主要数据结构——页表

要使用这个分页结构(页表)需要的硬件支持:

  • 内存管理单元(MMU)
  • TLB
  • 页表寄存器(PTR)

十、当前页表如下。页大小为1024字节,该程序分配2个帧,页号0先装入内存。采用先进先出和局部置换策略,现在访问逻辑地址为3000的字节,问在这个过程中发生了什么主要事件并写出 置换后的页表。

 局部置换策略:每个进程在物理内存中有自己的帧集合,不能访问其他进程的帧集合

十一、比对FIFO算法和LRU算法

FIFO优先淘汰最先进入内存的页面,但是可能置换出去的是很久之前初始化并且一直在用的变 量。性能很差,存在Belady异常。上述结果可以看出,对FIFO而言,增加分配给作业的内存 块数反而出现缺页次数增加的异常现象。给进程分配4个帧产生的页面错误率比分配 3个帧还 多。

LRU优先淘汰最近最久没访问的页面。和最优置换(OPT)一样,都没有Belady异常(它们属 于同一种算法,叫做栈算法)。效率较高,是一种经常被使用的页置换算法。

十二、增强的二次机会算法的基本思想;为什么会发生抖动,怎么解决?

增强的二次机会算法的基本思想:

若用(访问位,修改位)的形式表述,则

第一轮:淘汰(0,0)

第二轮:淘汰(0,1),并将扫描过的页面访问位都置为0

第三轮:淘汰(0,0)

第四轮:淘汰(0,1)

将引用位和修改位作为一组有序对来改进第二次机会算法。

  • (0,0)代表近期既没有被使用过,也没有被修改过,是最佳的页面置换。
  • (0,1)代表近期没有被使用过但是被修改过的页面,是不太好的页面置换,因为需要将该页面写回磁盘。
  • (1,0)代表近期被使用过但是没有被修改的页面,可能很快会被再次使用。
  • (1,1)代表近期既被使用过又被修改过,可能很快会再次使用,并且置换时需要写回磁盘。

每个页面必然都属于上述这四种类型的集合。当需要页面置换时,可以采用与Clock算法一样的策略:检查页面的类型(不是仅仅检查引用位),我们替换掉最低类型中的一个页面(如果这一类型的页面有的话)。因为可能并不存在(0,0)类型的页面,这时就选择(0,1)类型的页面,依此类推。增强型第二次机会算法的亮点在于它赋予了那些被修改过的页面更高的优先级,从而降低了所需要I/O的数量。

抖动主要原因:进程频繁访问的页面数目高于分配给进程可用的物理块数

防止抖动的方法:采用可变分配方法分配进程物理块数。

  1. 计算进程的工作集
  2. 将工作集中的帧数做一个求和得到一个总的工作集大小
  3. 驻留集(给进程分配的物理块数)不小于上面求得总的工作集大小 

 如果出现抖动得解决方法:

  • 减少并发进程数目
  • 增加物理内存块数
  • 优化页面置换策略

十三、三种磁盘空间分配方法(contiguous、linked、indexed)的优缺点

连续分配:对每个文件都从磁盘中连续地分配磁盘块给需要的文件。

  • 实现简单、存取速度块、效率高
  • 难以进行文件拓展,会产生外碎片

链接分配: 分配给文件磁盘块时,这些块可以不连续,彼此间用指针相联系

  • 不存在外碎片;实现简单;文件可以拓展,增加文件内存
  • 指针本身占用空间;无法实现随机读取;可靠性差,一旦其中一个指针出错整个内存分配都会出问题(文件分配表FAT改进)

索引分配:从空闲块中拿出一块用作索引块,在索引块中放置其他空闲块的指针,用以查找到其他空闲块的物理位置

  • 不存在外碎片;文件可拓展;
  • 索引块本身就是一个空间消耗(即使只有一两个指针也要耗费一个索引块内存) 

十四、基于磁盘的分配方法,设计一种高效的磁盘空闲空间分配和回收方法,说出基本思想,操作过程和数据结构。

空闲空间分配以及回收方法——空闲空间管理

空闲空间管理方法有空闲表法、链表法、组法、位图法

①空闲表法 ②空闲链表法:[空闲盘块链]将所有空闲磁盘块用链表链接起来,并将指向第一个空闲块的头指 针保存在磁盘的超级块上,同时也缓存在内存中。[空闲盘区链/计数counting]类似于内存动态分区。 ③位示图法:将空闲空间表现为位图,每块空闲空间用一位表示,如果空闲则为1,已分配则为 0。 ④成组链接法:把顺序的n个空闲扇区地址保存在第一个空闲扇区内,其最后一个空闲扇区内 则保存另一组顺序空闲扇区的地址,如此继续,直至所有空闲扇区均予以链接。系统只需要保 存一个指向第一个空闲扇区的指针。

十五、某磁盘文件区16GB,每个磁盘块为1KB,

(1)若空闲存储空间采用位图管理方法那么位图需占用多少个盘块

(2)若采用FAT,FAT中每个盘块地址用4字节表示,问FAT表需要几个盘块

1、

16GB=2^34B

2^34B/2^10B=2^24块

在位图管理中,每块用一位(1bit)来表示,所以需要2^24b来表示

2^24b=2^21B来表示位图

2^21B/2^10B=2^11块 (磁盘来存储位图)

2、

16GB=2^34B

2^34B/2^10B=2^24块

表示磁盘文件区有2^24块磁盘块

FAT方法是链表法的改进,文件分配表(FAT)中将有2^24条项(每一个块一个项)

由于每个盘块地址用4b表示,所以有2^24*4B=2^26B来表示

2^26B/2^10B=2^16块

十六、某文件系统为一级目录,文件的数据一次性写入磁盘,已经写入的文件不可修改,但可以多次创建新文件,请回答:

(1) 采用哪种文件物理结构形式更适合?说明理由,为定位文件数据块,需要FCB中设置哪些相关的描述字段?(10分)

(2) 为快速找到文件,对于FCB是集中存储好,还是与对应文件数据块连续存储好?为什么?(10分)

(1)连续更合适。因为一次写入不存在插入问题,而且写入文件之后不需要修改,连续的数据块组织方式很适合一次性写入磁盘不再修改的情况,同时连续存储相对链式和索引省去了指针的空间开销,支持随机查找,查找速度最快。FCB中包括:存放文件的设备名、文件在外存的起始盘块号、文件长度。

(2)FCB集中存储较好。FCB存储有文件的很多重要信息,同时是文件目录的重要组成部分,在检索时,通常会访问对应文件的FCB。如果将FCB集中存储,则可以减少在检索过程中产生的访盘次数,提高检索速度。

十七、假如盘块的大小为4KB,每个盘块号占4个字节,在两级索引分配时,允许的最大文件是多少?(请写出计算过程)

假如盘块的大小为4KB,每个盘块号占4个字节,则一个索引块可含 4KB/4B=1K个盘块号,

于是两级索引最多可含1K×1K = 1M个盘块号,因此,允许的最大文件长度为4KB×1M = 4GB。

十八、简要描述操作系统中打开文件的工作过程(等价于 如何通过文件名找到文件)

 用户给 open()传入一个文件的逻辑路径名,这时先将该文件系统的目录结构加载进内存,根据 文件名,操作系统会首先对系统范围内的打开文件表进行搜索(节省时间)。 如果该文件已经被其他进程打开了,则直接将该进程的打开文件表中的指针指向系统范围打开文件表的这一项,同时,系统打开文件表该文件引用计数加1。 如果该文件在系统范围文件表中不存在,说明该文件第一次打开,则对该文件系统的目录表进行搜索,依次查找到叶结点,叶结点包含了一个该文件控制节点号,即控制节点的物理位置指 针,将这个指针返回给用户,同时在系统范围打开文件表中新注册一行这个文件的信息,将该 进程的打开文件表中指针指向这条新信息,open()操作的任务就完成了。

  • 文件描述符表:用于跟踪和管理应用程序已打开的文件,包含文件描述符和相关的文件控制块指针。
  • 文件控制块(FCB):用于描述一个具体文件的数据结构,包含文件的各种属性和状态信息。
  • 文件表:更广义地指所有打开文件的集合,包括文件描述符表和每个文件的具体控制块(如FCB)。

十九、三种磁盘空间分配方法(连续、链接、索引)FCB中的描述字段

①连续分配:file start length

②链接分配:file start end

③索引分配:file index_block

二十、非阻塞和阻塞I/O是什么,主要有什么不同,分别用在哪里?

阻塞 I/O:当应用程序发出一个阻塞系统调用时,应用程序挂起,应用程序从运行队列转入等 待队列。等系统调用完成之后再回到就绪队列,在合适的时候继续运行。绝大多数操作系统为 应用程序提供的都是阻塞系统调用,因为它代码更加简单,更容易理解。

用在低速I/O的设备上

非阻塞IO模型:应用进程需要不断询问内核数据是否就绪,在内核数据还未就绪时,应用进程还可以做其他事情。

用在高速I/O的设备上

总结

如果觉得对你有帮助,辛苦友友点个赞,收个藏呀~~~

知识来源:操作系统概念(黑宝书)、山东大学高晓程老师PPT及课上讲解、山东大学操作系统往年题、部分考研题。不要私下外传

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1882034.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Stateflow快速入门系列(七): 使用时序逻辑调度图动作

要定义 Stateflow 图在仿真时间的行为,请在图的状态和转移动作中包含时序逻辑运算符。时序逻辑运算符是内置函数,告知状态保持激活的时间长度或布尔条件保持为 true 的时间长度。使用时序逻辑,您可以控制以下各项的时序: 各状态之…

守护矿山安全生产:AI视频分析技术在煤矿领域的应用

随着人工智能(AI)技术的快速发展,其在煤矿行业的应用也日益广泛。AI视频智能分析技术作为其中的重要分支,为煤矿的安全生产、过程监测、效率提升和监管决策等提供了有力支持。 一、煤矿AI视频智能分析技术的概述 视频智慧煤矿AI…

[数据库]mysql用户管理权限管理

目录 ​编辑用户管理​编辑 权限管理 ​编辑 ​编辑 ​编辑案例​编辑 细节 ​编辑 用户管理 我们用创建的用户在登录之后可以看到他和root看到的数据库是完全不一样的 权限管理 案例 登录这个账户可以看到还看不到teatdb这个数据库, 因为还没有授权 分配权限 过来刷新…

OpenCV 张正友标定法(二)

文章目录 一、简介二、实现代码三、实现效果参考资料一、简介 在之前的博客OpenCV 张氏标定法中,我们没有考虑镜头畸变等因素,因此计算出的内参与外参均是理想情况下的数值,而如果我们考虑到镜头的畸变: 我们就需要考虑使用最小二乘法最小化像素坐标的重投影误差(上述所求…

007-GeoGebra基础篇-构建等边三角形

今天继续来一篇尺规作图,可以跟着操作一波,刚开始我写的比较细一点,每步都有截图,后续内容逐渐复杂后我就只放置算式咯。 目录 一、先看看一下最终效果二、本次涉及的内容三、开始尺规画图1. 绘制定点A和B2. 绘制线段AB3. 以点A为…

基于STM32的智能电池管理系统

目录 引言环境准备智能电池管理系统基础代码实现:实现智能电池管理系统 4.1 数据采集模块4.2 数据处理与分析4.3 控制系统实现4.4 用户界面与数据可视化应用场景:电池管理与优化问题解决方案与优化收尾与总结 1. 引言 智能电池管理系统(Ba…

C语言--vs使用调试技巧

1.什么是bug? 1.产品说明书中规定要做的事情,而软件没有实现。 2.产品说明书中规定不要做的事情,而软件确实现了。 3.产品说明书中没有提到过的事情,而软件确实现了。 4.产品说明书中没有提到但是必须要做的事情,软件确没有实…

预付式消费,今起实行!

近年来,随着我国经济社会快速发展,消费新业态、新模式不断涌现,消费者权益保护也面临新情况、新问题。 大数据杀熟、自动续费难取消、网络直播带货“以假充真”“以次充好”、预付式消费商家跑路……数据显示,2023年,…

Vue 常见面试题及答案

本人详解 作者:王文峰,参加过 CSDN 2020年度博客之星,《Java王大师王天师》 公众号:JAVA开发王大师,专注于天道酬勤的 Java 开发问题中国国学、传统文化和代码爱好者的程序人生,期待你的关注和支持!本人外号:神秘小峯 山峯 转载说明:务必注明来源(注明:作者:王文峰…

鸿蒙:页面路由使用

页面路由使用步骤: 1.导入Router模块 2.使用路由功能,以pushUrl模式为例 3.接收参数、返回 4.此时的路由是不能使用的,需要到main_pages.json中进行注册

vscode的一些使用问题

vscode使用技巧 1、快捷键(1)打开命令面板(2)注释(3)删除行(4)上下移动光标(5)光标回退(6)复制行(7)插入空白行…

opencv编译报错OpenCV does not recognize MSVC_VERSION “1940“

具体如下: CMake Warning at cmake/OpenCVDetectCXXCompiler.cmake:182 (message):OpenCV does not recognize MSVC_VERSION "1940". Cannot set OpenCV_RUNTIME Call Stack (most recent call first):CMakeLists.txt:174 (include) 打开源码\opencv\sources\cmak…

【正点原子K210连载】第十四章 按键输入实验 摘自【正点原子】DNK210使用指南-CanMV版指南

1)实验平台:正点原子ATK-DNK210开发板 2)平台购买地址https://detail.tmall.com/item.htm?id731866264428 3)全套实验源码手册视频下载地址: http://www.openedv.com/docs/boards/xiaoxitongban 第十四章 按键输入实…

FPGA - 图像灰度化

一,灰度图像概念 灰度数字图像是每个像素只有一个采样颜色的图像。这类图像通常显示为从最暗黑色到最亮的白色的灰度,尽管理论上这个采样可以任何颜色的不同深浅,甚至可以是不同亮度上的不同颜色。灰度图像与黑白图像不同,在计算机…

50+k8s常用命令,助你成为k8s大牛!

Kubernetes是一个强大的容器编排平台,不管是运维、开发还是测试或多或少都会接触到,熟练的掌握k8s可大大提高工作效率和强化自身技能。 集群管理 1. 查看集群节点状态: kubectl get nodes2. 查看集群资源使用情况: kubectl top nodes3. 查看集群信息…

【MySQL】数据库——备份与恢复,日志管理1

一、数据备份的重要性 1.备份的主要目的是灾难恢复 在生产环境中,数据的安全性至关重要 任何数据的丢失都可能产生严重的后果造成数据丢失的原因: 程序错误人为,操作错误运算错误磁盘故障灾难(如火灾、地震)和盗窃 2.数据库备份…

IPFS 的开发对接流程

IPFS 的对接流程通常包括以下几个步骤,请注意,IPFS 的对接流程可能因您的具体需求而异。建议您在进行任何操作之前仔细阅读相关文档。北京木奇移动技术有限公司,专业的软件外包开发公司,欢迎交流合作。 1. 安装 IPFS 下载并安装 …

Java外卖点餐连锁店餐饮生鲜奶茶外卖店内扫码点餐源码同城外卖校园外卖源码

外卖点餐连锁店餐饮生鲜奶茶外卖小程序:打造一站式便捷服务 🚀 引领外卖新潮流:小程序的力量 在数字化时代,外卖小程序已成为餐饮行业的新宠。它不仅提供了便捷的点餐服务,还融合了连锁店、餐饮生鲜、奶茶等多种业务…

[Shell编程学习路线]——shell脚本中case语句多分支选择详解

🏡作者主页:点击! 🛠️Shell编程专栏:点击! ⏰️创作时间:2024年6月21日16点30分 🀄️文章质量:95分 ————前言———— 在Shell编程中,处理多种条件…

强度理论的相当应力在坐标图里的表示

以下的图均只考虑二维,且没有切应力,有切应力的情况可以转换成只有两个正应力的情况,另外,这里画出的图均认为相当应力就是许用应力 第一,二强度理论用于脆性材料 两种强度理论的图均明显有一个转角,这是因…