操作系统技巧总结

操作系统复习

第1章 操作系统概论

定义:管理系统资源、控制程序执行、改善人机界面、提供各种服务,并合理组织计算机工作流程和为用户方便有效的使用计算机提供良好运行环境的一种系统软件。
功能:处理器管理、存储管理、设备管理、文件管理、联网和通信管理
特性:并发性、共享性(1.透明资源共享 2.独占资源共享)、异步性
分类:批处理操作系统、分时操作系统、实时操作系统

第2章 处理器管理

进程定义:进程是具有独立功能的程序在某个数据集合上的一次运行活动,也是操作系统进行资源分配和保护的基本单位。
进程状态和转换:p73
三态模型:运行态、就绪态、等待态
五态模型:新建态、终止态提出的原因?
要求会画图,解释某些转换是不存在的。

引入多线程的动机:减少程序并发执行时所付出的时空开销,使得并发颗粒度更细、并发性更好。
线程的优点:快速线程切换、通信易于实现、减少管理开销、并发程度提高

PCB(Process Control Block)进程控制块:进程存在的唯一标识,是操作系统用来记录和刻画进程状态及环境信息的数据结构,是进程动态特征的汇集,也是操作系统掌握进程的唯一资料结构和管理进程的主要依据。p75

TCB的概念?
动态/静态 优先级?

处理器调度:p101 例题

先来先服务算法

最短作业优先算法(概念)

最短剩余时间优先算法

最高响应比优先算法(概念)

第3章 同步、通信与死锁

佰恩斯坦条件?Bernstein(简答)

死锁:一组进程因争夺资源陷入永远等待的状态。
饥饿:一个可运行进程由于其他进程总是优先于它,而被调度程序无限期的拖延而不能被执行。

进程同步:为完成共同任务的并发进程基于某个条件来协调其活动,因为需要在某些位置上排定执行的先后次序而等待、传递信号或消息所产生的协作制约关系。

临界区:并发进程中与共享变量有关的程序段。
临界资源:共享变量所代表的资源,即一次仅能供一个进程使用的资源。
临界区调度的三个原则(互斥使用,有空让进;忙则要等,有限等待;择一而入,算法可行。):

一次至多只有一个进程进入临界区内执行。

如果已有进程在临界区中,试图进入此临界区的其他进程应等待。

进入临界区内的进程应在有限时间内退出,以便让等待队列中的一个进程进入。

实现临界区管理的软件算法:
分析

是否会出问题?

何时出?

实现临界区管理的硬件设施:

关中断

测试并设置指令

对换指令

信号量与PV操作:p134

pv操作定义(一元、一般)?
综合题:

5位哲学家就餐问题 (无死锁解法) p139

生产者-消费者问题(多对多、多缓冲区)p140

读者-写者问题 p141

理发师问题 p142

和尚打水

死锁

定义:如果一个进程集合中的每个进程都在等待只能由此集合中的其他进程才能引发的事件,而无限期的陷入僵持的局面。
产生的条件:

互斥条件

占有和等待条件

不剥夺条件

循环等待条件

死锁避免:综合题15分
银行家算法的数据结构 p163
算法描述:

T0时刻的安全序列

进程P1请求资源(能否满足?为什么?)

第4章 存储管理

程序的链接种类:(填空)

静态链接

动态链接

运行时链接

静态地址重定位:由装载程序实现装载代码的加载和地址转换,把它装入分配给进程的内存指定区域,其中的所有逻辑地址修改成内存物理地址。
动态地址重定位:由装载程序实现装载代码模块的加载,把它装入分配给进程的内存指定区域,但对链接程序处理过的应用程序的逻辑地址则不做任何修改,程序内存起始地址被置入硬件专用寄存器——重定位寄存器。程序执行过程中,每当cpu引用内存地址(访问程序和数据)时,由硬件截取此逻辑地址,并在它被发送到内存之前加上重定位寄存器的值,以便实现地址转换。

分页存储管理 p206
概念:

页面

页框

逻辑地址

内存页框表

页表

分页/分段 动态链接库的实现原理?(说明+画图)

综合题:

给出逻辑地址,求物理地址?(画图)

给出逻辑地址、页面大小,计算物理地址?

分段和分页的比较(简答):
分段是信息的逻辑单位,由源程序的逻辑结构及含义所决定,是用户可见的,段长由用户根据需要来确定,段起始地址可从任何内存地址开始。在分段方式中,源程序(短号、段内位移)经链接装配后仍保持二维(地址)结构,引入目的是满足用户模块化程序设计的需要。
分页是信息的物理单位,与源程序的逻辑结构无关,是用户不可见的,页长由系统(硬件)确定,页面只能从页大小的整数倍位置开始。在分页方式中,源程序(页号、页内位移)经链接装配后变成一维(地址)结构,引入目的是实现离散分配并提高内存利用率。

缺页中断率 p223
概念:不成功访问次数?
画图,求缺页中断率? p229

第5章 设备管理

I/O控制方式:(填空)

轮询方式

中断方式

DMA方式

通道方式

缓冲技术:
单缓冲 p265
双缓冲 p266

搜查定位:(例题、简答)p270

先来先服务算法

最短查找时间优先算法

扫描算法

电梯调度算法

循环扫描算法

参考书目:

-《操作系统教程(第五版)》费翔林、骆斌著 高等教育出版社

以上就是操作系统技巧总结的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/185997.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
composer怎么记忆
上一篇 2025年11月1日 10:21:56
基于Swoole开发高可用的在线客服系统
下一篇 2025年11月1日 10:21:58

相关推荐

  • 比特币新手教程 比特币交易平台有哪些

    比特币是一种去中心化的数字货币,基于区块链技术实现点对点交易,具有匿名性、有限发行和不可篡改等特点;新手可通过交易所购买,P2P交易获得比特币,常用平台包括Binance、OKX和Huobi;交易流程包括注册账户、实名认证、绑定支付方式、充值法币并下单购买,可选择市价单或限价单;比特币存储方式有交易…

    2026年5月10日
    000
  • 修复点击时按钮抖动:CSS垂直对齐实践

    本文探讨了在Web开发中,交互式按钮(如播放/暂停按钮)在点击时发生意外垂直位移的问题。通过分析CSS样式变化对元素布局的影响,我们发现这是由于按钮不同状态下的边框样式和内边距改变,以及默认的垂直对齐行为共同作用所致。核心解决方案是利用CSS的vertical-align属性,将其设置为middle…

    2026年5月10日
    100
  • Golang使用Protobuf定义接口与消息格式

    Protobuf通过字段编号实现兼容性,新增字段可忽略、删除字段可保留编号,确保新旧版本互操作,支持服务独立演进。 在Golang项目中,利用Protobuf定义接口和消息格式,本质上是为服务间通信构建了一套高效、类型安全且跨语言的契约。它让数据结构清晰可见,RPC调用标准化,极大地简化了分布式系统…

    2026年5月10日
    000
  • 硬盘数据被误删除怎么办?教你快速找回删除的文件!

    硬盘数据被误删除,别慌!恢复数据并非不可能,关键在于你接下来的操作。立刻停止对该硬盘的任何写入操作,然后尝试使用专业的数据恢复软件。 解决方案 首先,数据恢复的原理是,删除文件后,操作系统只是将文件占用的空间标记为“可覆盖”,但文件本身的数据可能还存在于硬盘上。所以,避免新的数据写入覆盖掉旧数据,是…

    2026年5月10日
    000
  • Python官网用户调查的参与方式_Python官网反馈提交详细教程

    答案是通过访问Python官网新闻页面、邮件邀请链接或GitHub仓库提交反馈。具体为:访问官网查找用户调查公告,或点击邮件中的专属链接参与,在GitHub的cpython仓库提交技术建议,并注意如实填写问卷与保护隐私。 如果您希望参与Python官网的用户调查并提交反馈,可以通过官方指定的渠道完成…

    2026年5月10日
    000
  • Go语言连接外部MySQL数据库:DSN配置与常见错误解析

    本文详细阐述了go语言使用`go-sql-driver/mysql`驱动连接外部mysql数据库的正确方法。重点介绍了数据源名称(dsn)的规范格式,特别是主机地址部分的配置,以避免常见的“getaddrinfow: the specified class was not found.”等网络解析错…

    2026年5月10日
    000
  • php源码怎么运行手机_php源码手机运行环境搭建步骤【教程】

    可在手机上通过特定工具运行PHP源码。首先选择支持PHP的移动应用,安卓用户可安装UserLAnd或KSWEB,iOS用户可尝试iSH Shell或a-Shell;然后配置本地服务器环境,启动HTTP和PHP服务,将PHP文件放入指定根目录;接着可通过Termux搭建完整开发环境,更新包列表并安装P…

    2026年5月10日
    200
  • Go语言:检查预编译库的构建版本与平台信息

    本文详细介绍了如何利用go语言内置的`go tool pack`工具,从预编译的go静态库(`.a`文件)中提取其构建信息,包括go编译器版本、操作系统和cpu架构。当`go build`因库版本不匹配而失败时,此方法能帮助开发者准确诊断问题,确保构建环境与库的兼容性。 在Go语言的开发实践中,我们…

    2026年5月10日
    000
  • 解决Python脚本中相对路径文件找不到的常见问题与策略

    本文旨在解决python脚本中因相对路径处理不当导致的文件找不到错误,尤其是在项目迁移后。文章将深入探讨python中相对路径的工作原理、当前工作目录(cwd)的影响,并提供使用`os.getcwd()`诊断问题以及利用`os.path.dirname(__file__)`结合`os.path.jo…

    2026年5月10日
    000
  • Golang如何提升TCP长连接处理效率_Golang TCP长连接处理性能优化实践详解

    答案:通过非阻塞I/O、单Goroutine双工模型、sync.Pool对象复用、TCP_NODELAY优化及高效心跳管理,结合系统调优,可显著提升Golang百万级TCP长连接处理效率。 在高并发网络服务场景中,TCP长连接的处理效率直接影响系统的吞吐能力和资源消耗。Golang凭借其轻量级Gor…

    2026年5月10日
    000
  • Golang 文件IO操作与性能优化实践

    合理使用Go标准库并优化IO策略可显著提升文件处理性能。1. 使用bufio减少系统调用,适合小块读写;2. 大文件用流式读取避免OOM,小文件可一次性加载;3. 并发分片读取大文件并配合预读提升吞吐;4. 结合系统调优如O_DIRECT、关闭atime等防止IO瓶颈。 Go语言在文件IO操作上提供…

    2026年5月10日
    000
  • c++如何调用系统命令_c++执行系统命令方法

    使用std::system()可执行系统命令,需包含cstdlib头文件,传入命令字符串,返回值表示执行结果。示例:Linux下用”ls -l”列出文件,Windows下用”dir”。返回0表示成功,非0表示失败,可用于判断命令执行状态。注意跨平台命令…

    2026年5月10日
    200
  • 火币app下载 火币app官方下载最新版 火币htx交易所安卓版

    若您需要下载火币htx官方最新版的安卓应用,最安全可靠的方式是通过其官方网站进行获取。为了保障您的数字资产安全,请务必避免使用任何非官方渠道提供的下载链接或安装包,因为这些来源可能包含恶意软件,对您的账户和资金构成威胁。访问官网后,通常可以在页面显眼位置找到app下载入口或二维码。 火币官网直达: …

    2026年5月10日
    000
  • php文件怎么在服务器运行_php文件上传服务器后运行的配置方法

    首先确认服务器已安装PHP环境并正确配置Web服务器支持PHP,将文件放入指定Web目录并设置权限,通过测试页面验证执行,同时确保上传方式与编码格式无误。 如果您已经将PHP文件上传至服务器,但无法正常执行,可能是由于服务器环境未正确配置或缺少必要的服务支持。以下是使PHP文件在服务器上成功运行的详…

    2026年5月10日
    000
  • c++怎么处理跨平台编译问题_c++跨平台编译方法

    答案是使用条件编译、跨平台构建系统、避免平台特定API和统一依赖管理。通过预定义宏区分平台,采用CMake生成多平台项目文件,优先使用标准库或跨平台库如std::filesystem、Boost.Asio,结合vcpkg或Conan管理依赖,确保代码可移植性和构建自动化,从而实现高效稳定的C++跨平…

    2026年5月10日
    000
  • Go语言中随机数生成器的正确播种方法与性能优化

    本文深入探讨Go语言中随机数生成器的正确播种方法,强调仅需在程序启动时播种一次的重要性。通过分析常见错误(如在循环中重复播种),我们展示了如何避免性能瓶颈并确保生成高质量的随机序列。文章提供了优化的代码示例,涵盖了高效的字符串构建技巧,旨在帮助开发者编写健壮且高效的随机数生成逻辑。 理解伪随机数生成…

    2026年5月10日
    000
  • Go语言集成SQLite3数据库:使用go-sqlite3库的实践指南

    本文旨在为Go语言开发者提供一套完整的SQLite3数据库集成指南。我们将重点介绍如何使用广受欢迎的github.com/mattn/go-sqlite3库,涵盖其安装、数据库连接、表创建、数据插入、查询、更新及删除等核心操作,并提供实用的代码示例和注意事项,助您高效地在Go应用中实现SQLite3…

    2026年5月10日
    000
  • Python中如何执行Shell命令?

    在python中,执行shell命令可以通过subprocess模块实现。1) 使用subprocess.run()执行简单命令,如echo。2) 通过input参数传递数据给命令,如grep。3) 使用check=true处理命令失败,并捕获calledprocesserror。4) 利用subp…

    2026年5月10日
    000
  • 阿里云服务器无法远程连接:如何排查问题并解决?

    阿里云远程桌面问题困扰 当尝试远程访问位于香港的阿里云服务器时,发现无法连接。服务器配置看似合理,但仍无法连接。为此,我们寻求专家的帮助,以解决这一问题。 问题解决指南 一位经验丰富的专家提供了以下解决问题的步骤: 检查主机是否配置了公网 IP。验证云上的网络是否配置了防火墙端口开放。对于不同类型的…

    2026年5月10日
    000
  • VS Code如何配置C++17或C++20标准进行编译

    答案是配置tasks.json和c_cpp_properties.json文件。首先确认编译器版本支持C++17/20,然后在tasks.json的args中添加-std=c++17或-std=c++20以指定编译标准,在c_cpp_properties.json中设置cppStandard为&#8…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信