软考中级-操作系统
1 操作系统地位

计算机系统由硬件和软件组成,未配置软件的称为裸机,但这会导致效率低下。
操作系统是为弥补用户与硬件之间的鸿沟的一种系统软件,汇编、编译、解释、数据库管理系统等系统软件和其他应用软件都在此基础。
2 进程管理
又称处理机管理。
进程是资源分配和独立运行的基本单位。
进程管理负责管理进程间并发性、资源竞争和合作。
(1)程序与进程
程序顺序执行的特征
前趋图是一个有向无环图,表示程序执行的顺序,结点为程序段操作,有向边表示前后关系,如1->2,表示先程序1执行结束后再执行程序2,1为前趋2为后继。
顺序执行特征包括顺序性(顺序执行)、封闭性(每次执行的程序独占资源)、可再现性(相同输入得到的输出相同)。
PV操作:操作系统中一经典操作,可实现同步、互斥、前趋关系。
PV使用:每两个进程之间会有一个信号量,初始为0,前趋执行结束后会对该信号量做V操作(信号量+1),当后继发现信号量为1,会执行P操作(信号量-1),依次类推。
程序并发执行的特征
采用多道程序设计技术,可使主存中的多道程序处于并发状态。
没有前趋关系的程序段可以并发执行。

并发执行特征为:失去封闭性和可再现性(引入同步和互斥问题);程序和机器执行程序的活动顺序不再一一对应;并发间的程序员有相互制约性。
(2)进程状态及状态间的切换
三态模型:运行、就绪、阻塞

运行
运行时就是运行态,单处理机只有一个运行态的进程。
就绪
除了CPU,其他资源均已被进程获得,万事俱备只欠CPU。
阻塞
又称等待或睡眠,进程正在等待某一事件发生(如等待IO完成),此时给CPU也没用。
五态模型

3 进程间的通信
由于并发的存在,进程间存在资源共享和互相合作的关系,进程通信就是指进程间的信息交换过程。
同步:合作的进程之间直接制约问题。
互斥:申请临界资源(同时只能供一个进程使用的资源,如打印机)的进程间的间接制约问题。
(1)临界区
临界区:进程中对临界资源进行操作的那段程序。
临界区四大原则
有空即进
无空则等
有限等待
等待的程序要保证能在有限时间内访问临界资源,不能让人家一直等好久,进入“饥饿”状态。
让权等待
当进程不能进入临界区,应立即释放CPU,不能占着茅坑不拉屎,进入“忙等”状态。
(2)信号量机制
有效控制进程间同步与互斥的工具,主要有整型信号量、记录型信号量,信号量集机制。
整型信号量与PV操作
此信号量是一个整型变量,有以下两种:
公共型信号量:实现互斥操作,初值为1或资源数量。
私有型信号量:实现同步操作,初值为0或某正整数。
信号量用S表示,S>=0表示可用资源数,S<0其绝对值表示阻塞队列中等待该资源的进程数。
PV操作
P申请一个资源,V释放一个资源,如:

PV操作实现互斥

PV操作实现同步
下图为单缓冲区的例子:

下图为多缓冲区的例子:

4 死锁
由同类资源分配不当引起,当系统中有m个资源被n个进程共享,每个进程需要k个资源,当
,即资源小于进程所需数,就可能会发生死锁。
判断是否会发生死锁(最小个数):
,满足就不会死锁。
进程资源图

先分配,再申请,箭头从进程指入为分配,指出为申请。
化简(是否可以都执行且不会死锁),上图化简为p1->p2->p3
死锁的处理
死锁避免策略
银行家算法:每次分配资源前先预演分配后是否会出现死锁,安全才分配。提高资源利用率,但增加了系统开销。安全指按照一定顺序轮流为进程分配资源,直至达到最大需求(每个进程最终都能运行),此时这个分配序列称为安全序列。若找不出这个序列,则为不安全。
5 线程
为了节省开销,进程在一个系统中不宜过多,因此引入线程将进程的两大特性(分配资源的基本单位,独立调度和分配的基本单位)中的后者分配给线程。一个线程受阻,其他线程可继续运行。
线程是进程的一部分,是系统调度和分配的基本单位,仅拥有一点必须的资源(程序计数器,一组寄存器和栈),他和所属进程下的其他所有线程共享进程的所有资源,但这些线程之间是不可见的。
6 分页/段页存储管理
分页:页号+页内地址
段页:段号+段内页号+页内地址
7 缓冲区
单缓冲区
缓冲区非空不输入,非满不传送。
并行传输n条作业时间:

双缓冲区
用时


8 磁盘调度算法
先来先服务(FCFS)
谁来谁先,不考虑访问的位置。
最短寻道时间有限(SSTF)
先服务距离当前磁道最近的,不考虑请求服务顺序。
扫描算法(SCAN)或电梯调度算法
先沿距离当前磁道最近的请求方向服务,直到该方向没有请求,再反向。
旋转调度算法
读取必须和处理同步,读取完后才开始处理,会因为处理后当前磁头所在的读取位置与本次该读取的位置不同出现时间差,导致等待时间很长。
优化的方案:修改记录所在的扇区位置,使得读取完上一记录后,磁头恰好停留在下一条要处理的记录。
阶段补充
移动臂就是磁头,上述说的距离是指柱面号。

9 文件目录
为实现按名存取,系统为每个文件设置了描述文件的数据结构——文件控制块(FCB),其中最少包含了文件的物理地址和文件名。文件控制块的有序集合称为文件目录,专门用于文件检索,此目录若被修改对系统有较大影响。
文件控制块包含三类信息
基本信息类
文件名、物理地址、文件长度、文件块数。
存取控制信息类
存取权限RWX。
使用信息类
创建时间、上次修改时间、访问时间...
目录结构
影响文件的存取速度、共享性和安全性。
一级目录结构
链式结构,所有文件一根链,速度慢。
二级目录结构
分为主目录和用户目录, 为每个用户分配了一个用户目录存储在主目录中,一个用户一根链,速度较快但共享时不方便。
多级目录结构(树形目录结构)
节点是目录,叶子节点是文件,有全文件名路径(从根节点开始)、绝对路径(从根节点开始)和相对路径(当前目录/.../)。
10 位示图
用二进制的一位来表示一个物理块的状态,下图为字长为32位的计算机中的位示图。

位示图的大小由磁盘空间中物理块总数决定,几个物理块位示图就有几位。
阶段补充
简单时间片时间片方法,用户数为n,时间片为q,每个用户响应时间为
。

磁盘调度中,不同柱面需要先移臂调度到目标柱面,再旋转调度到目标磁道。
相关文章:
软考中级-操作系统
1 操作系统地位计算机系统由硬件和软件组成,未配置软件的称为裸机,但这会导致效率低下。操作系统是为弥补用户与硬件之间的鸿沟的一种系统软件,汇编、编译、解释、数据库管理系统等系统软件和其他应用软件都在此基础。2 进程管理又称处理机管…...
MYD-Y6ULL开发笔记
MYD-Y6ULL开发 文章目录MYD-Y6ULL开发一、系统移植1. 核板说明2. 文件系统操作二、应用开发1. 应用自启动2. 应用编译3.系统应用4.网络5.系统参数一、系统移植 1. 核板说明 型号 MYIR-Y6UL Y2 V2-256N 256D-50I烧了固件命令 uuu.exe myd-y6ulx-y2-256n256d-core-base.auto2. 文…...
三天吃透Java虚拟机面试八股文
本文已经收录到Github仓库,该仓库包含计算机基础、Java基础、多线程、JVM、数据库、Redis、Spring、Mybatis、SpringMVC、SpringBoot、分布式、微服务、设计模式、架构、校招社招分享等核心知识点,欢迎star~ Github地址:https://github.com/…...
Spring Cloud Alibaba全家桶(二)——微服务组件Nacos注册中心
前言 本文为微服务组件Nacos注册中心相关知识,下边将对什么是 Nacos,Nacos注册中心(包括:注册中心演变及其设计思想、核心功能),Nacos Server部署(包括:单机模式、集群模式ÿ…...
命令执行漏洞 | iwebsec
文章目录1 靶场环境2 命令执行漏洞介绍3 靶场练习01-命令执行漏洞02-命令执行漏洞空格绕过03-命令执行漏洞关键命令绕过04-命令执行漏洞通配符绕过05-命令执行漏洞base64编码绕过4 命令执行漏洞危害01-读写系统文件02-执行系统命令03-种植恶意木马04-反弹shellpython反弹shellp…...
2023.02.26 学习周报
文章目录摘要文献阅读1.题目2.摘要3.介绍4.模型4.1 SESSION-PARALLEL MINI-BATCHES4.2 SAMPLING ON THE OUTPUT4.3 RANKING LOSS5.实验5.1 数据集5.2 验证方式5.3 baselines5.4 实验结果6.结论深度学习元胞自动机1.定义2.构成3.特性4.思想5.统计特征流形学习1.降维2.空间3.距离…...
局域网实现PC、Pad、Android互联
文章目录局域网实现PC、Pad、Android互联一、网络邻居1、 Windows 配置1.1 开启共享功能1.2 设置用户1.3 共享文件夹2、 Pad 连接二、 FTP & HTTP1、 电脑配置1.1 HTTP 服务1.2 FTP 服务2、 连接3、 电脑连接 FTP三、 其他方式局域网实现PC、Pad、Android互联 在我们使用多…...
AC自动机
AC自动机 该模型应用场景是什么样的?假如有一篇很长的文章,然后有一个敏感词表单,请从这篇文章里找出包含了哪些敏感词。即便是用KMP进行快速匹配,那也只能每次遍历整篇文章才能找到一种敏感词,KMP只适用于单一子串匹配…...
git入门
目录 1. git简介 1.1 git是什么 1.2 git与svn的区别 2. github 2.1 创建仓库 2.2 删除仓库 2.3 新建文件及文件夹 3. git的基本操作 3.1 配置账户及邮箱 3.2 git文件状态与工作区域 3.3 常用命令 3.4 克隆(clone) 3.5 查看git仓库的状态 3.…...
RK3568编译Android11和目录讲解
文章目录 前言一、下载android11源码二、环境搭建1.增加交换内存三、编译瑞芯微原厂源码四、目录讲解总结前言 本文记录在Ubuntu18.04中编译Android11,只有编译了源码,后面才能进行驱动的开发,有兴趣的小伙伴可以和我一起学习吧! 提示:以下是本篇文章正文内容,下面案例可…...
java泛型学习篇(二)
java泛型学习篇(二) 1 自定义泛型类 1.1 基本语法 Class 类型 <T,R,M...>{ //成员,其中...代表<>括号里面的参数可以有多个ja }1.2 注意点 1.2.1 属性和方法都是可以使用泛型的 T t;//属性使用泛型,合法public T getT() {return t;} //方法使用泛型,合法 publi…...
Java基础
Java基础Java基础一、课前问答二、概述三、Java的历史四、Java的特点五、计算机执行机制以及Java执行机制5.1 计算机的执行机制5.2 Java的执行机制六、常用DOS命令七、第一个Java程序八、包的使用九、编码规范十、注释Java基础 一、课前问答 1、什么是程序 2、什么是语言 3、什…...
骨骼控制(一)——动画动态节点(AnimDynamics)
文章目录一、引言二、骨骼控制三、UE蓝图中提供的骨骼控制节点——AnimDynamics动画蓝图节点1、什么是AnimDynamics动画蓝图节点①使用盒体计算惯性②使用约束来限制移动2、AnimDynamics节点的几种常用例子①单骨骼模拟②骨骼链模拟 <h2 id1>③群魔乱舞(这是错…...
Linux系统下搭建maven环境
文章目录前述从官网下载安装包安装 maven修改maven配置修改环境变量测试前述 安装 maven 环境前,需要先安装 java 环境,如果没有安装 java 环境,可以参考:https://blog.csdn.net/weixin_45583303/article/details/118631855 从官…...
English Learning - L2 语音作业打卡 Day3 2023.2.23 周四
English Learning - L2 语音作业打卡 Day3 2023.2.23 周四💌 发音小贴士:💌 当日目标音发音规则/技巧:🍭 Part 1【热身练习】🍭 Part2【练习内容】🍭【练习感受】🍓元音[ ɔ: ]&…...
RK3568平台开发系列讲解(驱动基础篇)GIC v3中断控制器
🚀返回专栏总目录 文章目录 一、什么是GIC二、GIC v3中断类型三、GIC v3基本结构3.1、Distributor3.2、CPU interface简介3.3、Redistributor简介3.4、ITS(Interrupt translation service)4、中断状态和处理流程沉淀、分享、成长,让自己和他人都能有所收获!😄 📢ARM多核…...
决策树、随机森林、极端随机树(ERT)
声明:本文仅为个人学习记录所用,参考较多,如有侵权,联系删除 决策树 通俗来说,决策树分类的思想类似于找对象。现想象一个女孩的母亲要给这个女孩介绍男朋友,于是有了下面的对话: 女儿&#x…...
软件测试之因果图法
因果图法 1. 概述 因果图法是一种**利用图解法分析输入条件、输出结果的各种组合情况,**从而设计测试用例的方法. 因果图法适用于有多个输入和多个输出,而且输入和输入之间有相互的组合关系,输入和输出之间有相互的制约和依赖关系. 使用场景和判定表…...
vue中子组件间接修改父组件传递过来的值
一、前言 Vue官方文档Props单向数据流讲解 Vue中遵循单向数据流,所有的 props 都遵循着单向绑定原则,props 因父组件的更新而变化,自然地将新的状态向下流往子组件,而不会逆向传递。这避免了子组件意外修改父组件的状态的情况&a…...
Java I/O
前言 关于IO, 想必你听过很多中I/O方式, 有的是OS视角的, 有的是JDK本身支持的, 有的是纯实现视角。但是作为一个developer, 我希望你能先搞清楚上下文之后, 再去理解内容, 否则容易抬杠。这个上下文有横向和纵向两个维度。纵向维度包括JDK底层, JDK上层包装库, 开发框架(如Ne…...
Python爬虫实战:研究MechanicalSoup库相关技术
一、MechanicalSoup 库概述 1.1 库简介 MechanicalSoup 是一个 Python 库,专为自动化交互网站而设计。它结合了 requests 的 HTTP 请求能力和 BeautifulSoup 的 HTML 解析能力,提供了直观的 API,让我们可以像人类用户一样浏览网页、填写表单和提交请求。 1.2 主要功能特点…...
学校招生小程序源码介绍
基于ThinkPHPFastAdminUniApp开发的学校招生小程序源码,专为学校招生场景量身打造,功能实用且操作便捷。 从技术架构来看,ThinkPHP提供稳定可靠的后台服务,FastAdmin加速开发流程,UniApp则保障小程序在多端有良好的兼…...
Springcloud:Eureka 高可用集群搭建实战(服务注册与发现的底层原理与避坑指南)
引言:为什么 Eureka 依然是存量系统的核心? 尽管 Nacos 等新注册中心崛起,但金融、电力等保守行业仍有大量系统运行在 Eureka 上。理解其高可用设计与自我保护机制,是保障分布式系统稳定的必修课。本文将手把手带你搭建生产级 Eur…...
什么是Ansible Jinja2
理解 Ansible Jinja2 模板 Ansible 是一款功能强大的开源自动化工具,可让您无缝地管理和配置系统。Ansible 的一大亮点是它使用 Jinja2 模板,允许您根据变量数据动态生成文件、配置设置和脚本。本文将向您介绍 Ansible 中的 Jinja2 模板,并通…...
ABAP设计模式之---“简单设计原则(Simple Design)”
“Simple Design”(简单设计)是软件开发中的一个重要理念,倡导以最简单的方式实现软件功能,以确保代码清晰易懂、易维护,并在项目需求变化时能够快速适应。 其核心目标是避免复杂和过度设计,遵循“让事情保…...
html css js网页制作成品——HTML+CSS榴莲商城网页设计(4页)附源码
目录 一、👨🎓网站题目 二、✍️网站描述 三、📚网站介绍 四、🌐网站效果 五、🪓 代码实现 🧱HTML 六、🥇 如何让学习不再盲目 七、🎁更多干货 一、👨…...
Netty从入门到进阶(二)
二、Netty入门 1. 概述 1.1 Netty是什么 Netty is an asynchronous event-driven network application framework for rapid development of maintainable high performance protocol servers & clients. Netty是一个异步的、基于事件驱动的网络应用框架,用于…...
站群服务器的应用场景都有哪些?
站群服务器主要是为了多个网站的托管和管理所设计的,可以通过集中管理和高效资源的分配,来支持多个独立的网站同时运行,让每一个网站都可以分配到独立的IP地址,避免出现IP关联的风险,用户还可以通过控制面板进行管理功…...
计算机基础知识解析:从应用到架构的全面拆解
目录 前言 1、 计算机的应用领域:无处不在的数字助手 2、 计算机的进化史:从算盘到量子计算 3、计算机的分类:不止 “台式机和笔记本” 4、计算机的组件:硬件与软件的协同 4.1 硬件:五大核心部件 4.2 软件&#…...
提升移动端网页调试效率:WebDebugX 与常见工具组合实践
在日常移动端开发中,网页调试始终是一个高频但又极具挑战的环节。尤其在面对 iOS 与 Android 的混合技术栈、各种设备差异化行为时,开发者迫切需要一套高效、可靠且跨平台的调试方案。过去,我们或多或少使用过 Chrome DevTools、Remote Debug…...
