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

🌈 个人主页:十二月的猫-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及课上讲解、山东大学操作系统往年题、部分考研题。不要私下外传

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【NOI】C++程序设计入门四

文章目录 前言一、浮点型(float和double)1.float类型2.double类型 二、保留小数的方法方法一:方法二: 三、样题讲解问题1:1603. 冷饮的价格?问题2:1957. 求三个数的平均数问题3:1602…

爬数据是什么意思?

爬数据的意思是:通过网络爬虫程序来获取需要的网站上的内容信息,比如文字、视频、图片等数据。网络爬虫(网页蜘蛛)是一种按照一定的规则,自动的抓取万维网信息的程序或者脚本。 学习一些爬数据的知识有什么用呢&#x…

(PC+WAP)高端大气的装修装潢公司网站模板

(PCWAP)高端大气的装修装潢公司网站模板PbootCMS内核开发的网站模板,该模板适用于装修公司网站、装潢公司网站等企业,当然其他行业也可以做,只需要把文字图片换成其他行业的即可;(PCWAP),同一个后台,数据即…

Vue2动态代理,换服务无须重启项目

1、痛点 当我们需要使用不同的服务器时,就需要手动修改vue.config.js中配置并重新启动项目。当项目越来越大时,会需要较长的时间来等待项目启动,如此反复,极大影响我们开发进度。 2、寻求解决方案 vue-cli 的代理是使用的http-p…

新勒索软件 Shinra 与 Limpopo 浮出水面

Shinra 勒索软件概览 Shinra 勒索软件的样本文件最早在 2024 年 4 月提交给公开的文件扫描服务。攻击者在部署和运行勒索软件前会先窃取受害者的数据,还会删除卷影副本以阻止数据恢复。 攻击者有时会使用亚文化的人物来进行命名,研究人员也怀疑 Shinra…

clion远程开发

clion远程开发 简要概括: 建立 SFTP 通讯,创建远程目录与本地目录的映射文件夹,就可以把本机文件夹中的文件用鼠标右键选中上全传,打开自动同步功能,后面更改文件就可以自动同步文件了。 一.新建SFTP远程链接服务 …

C++感受12-Hello Object 派生版

不变的功能,希望直接复用原有代码;变化的功能,希望在分开的代码里实现。 派生的基本概念和目的如何定义派生类以及创建派生对象派生对象的生死过程 0. 课堂视频 ff14-HelloObject-派生版 1. 派生的基本概念与目的 编程,或者说软…

无线领夹麦克风可以唱歌吗?推荐多款收音好的无线麦克风

如今是一个短视频营销飞速发展的时代,越来越多自媒体人通过短视频的方式来进行直播带货、生活Vlog、线上K歌等,记录下生活里那美丽的瞬间。不过也有不少新手视频创作者存在疑问:无线领夹麦克风可以唱歌吗? 答案是可以的&#xff0…

前端技术(二)——javasctipt 介绍

一、javascript基础 1. javascript简介 ⑴ javascript的起源 ⑵ javascript 简史 ⑶ javascript发展的时间线 ⑷ javascript的实现 ⑸ js第一个代码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>…

SSM“点点通”餐饮点餐小程序-计算机毕业设计源码11264

摘要 随着中国经济的飞速增长&#xff0c;消费者的智能化水平不断提高&#xff0c;许多智能手机和相关的软件正在得到更多的关注和支持。其中&#xff0c;微信的餐饮点餐小程序更是深得消费者的喜爱&#xff0c;它的出现极大地改善了消费者的生活质量&#xff0c;同时&#xf…

电商价格监测:品牌控价维权的关键利器

品牌在进行控价时&#xff0c;所面对的是线上成千上万条的商品链接&#xff0c;如果仅依靠人工&#xff0c;根本无法做到准确且全面地完成电商价格监测工作。因此&#xff0c;一套准确率高的电商价格监测系统对于品牌的控价维权而言&#xff0c;其重要性不言而喻。 在形形色色的…

昇思25天学习打卡营第八天|保存与加载

背景 提供免费算力支持&#xff0c;有交流群有值班教师答疑的华为昇思训练营进入第八天了。 今天是第八天&#xff0c;前七天的学习内容可以看链接 昇思25天学习打卡营第一天|快速入门 昇思25天学习打卡营第二天|张量 Tensor 昇思25天学习打卡营第三天|数据集Dataset 昇思25天…

GPT-5:下一代AI如何彻底改变我们的未来

GPT-5 发布前瞻&#xff1a;技术突破与未来展望 随着科技的飞速发展&#xff0c;人工智能领域不断迎来新的突破。根据最新消息&#xff0c;OpenAI 的首席技术官米拉穆拉蒂在一次采访中确认&#xff0c;GPT-5 将在一年半后发布&#xff0c;并描述了其从 GPT-4 到 GPT-5 的飞跃如…

分布式限流:Spring Cloud Gateway 限流

分布式限流&#xff1a;Spring Cloud Gateway 限流 在现代微服务架构中&#xff0c;流量控制是一个至关重要的部分。分布式限流作为一种有效的流量控制手段&#xff0c;能够帮助我们保护系统不被突发的流量冲垮。Spring Cloud Gateway支持多种限流方式。 什么是分布式限流 分…

嵌入式UI开发-lvgl+wsl2+vscode系列:8、控件(Widgets)(一)

一、前言 这里将介绍一系列控件&#xff0c;了解后就可以开始基础的开发了。 二、示例 1、Base Obj&#xff08;基础对象&#xff09; 1.1、示例1 #include "../../lv_examples.h" #if LV_BUILD_EXAMPLESvoid lv_example_obj_1(void) {lv_obj_t * obj1;obj1 lv…

商城积分系统的代码实现(下)-- 积分订单的退款与结算

一、接着上文 用户在消耗积分的时候&#xff0c;需要根据一定的逻辑&#xff0c;除了扣减账户的当前余额&#xff0c;还需要依次消费积分订单的余额。 private void updatePointsOrderByUse(Integer schoolId, Long userId, String pointsType, int usingPoints) {List<Po…

springboot+vue 开发记录(八) 前端项目打包

本篇文章涉及到前端项目打包的一些说明 我打包后的项目在部署到服务器上后&#xff0c;访问页面时按下F12出现了这种情况&#xff1a; 它显示出了我的源码&#xff0c;这是一种很不安全的行为 该怎么办&#xff1f;很简单&#xff1a; 我们只需要下载一点点插件&#xff0c;再…

怎样查看vsphere client 的登录日志

- 问题摘要&#xff1a; 怎样查看vsphere client 的登录日志 - 解决方案/工作方法 1.登录vsphere client > vc > Monitor > Tasks and Events > Events, 查看日志 2. 查看VC 的websso.log日志 /var/log/vmware/sso/websso.log 3. 可以把websso.log文件拿到本地电…

苏东坡传-读书笔记六

苏东坡今生的浩然之气用尽。人的生活也就是心灵的生活&#xff0c;这种力量形成人的事业人品&#xff0c;与生命俱来&#xff0c;由生活中之遭遇而显示其形态。正如苏东坡在潮州韩文公庙碑中所说&#xff1a;“浩然之气、不依形而立&#xff0c;不恃力而行&#xff0c;不待生而…

智能驾驶系列报告:特斯拉智能驾驶方案简剖

不同于绝大多数国内车企在自动驾驶上采取多传感器融合方案&#xff0c;特斯拉FSD在发展初期就摒弃激光雷达、且不配备高清地图&#xff0c;成为在感知层以摄像头为核心的纯视觉解决方案代表;其依靠车身搭载的摄像头来捕捉周围的环境信息&#xff0c;并经过算法及神经网络模型处…