软考中级-操作系统
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…...
浅谈 React Hooks
React Hooks 是 React 16.8 引入的一组 API,用于在函数组件中使用 state 和其他 React 特性(例如生命周期方法、context 等)。Hooks 通过简洁的函数接口,解决了状态与 UI 的高度解耦,通过函数式编程范式实现更灵活 Rea…...

地震勘探——干扰波识别、井中地震时距曲线特点
目录 干扰波识别反射波地震勘探的干扰波 井中地震时距曲线特点 干扰波识别 有效波:可以用来解决所提出的地质任务的波;干扰波:所有妨碍辨认、追踪有效波的其他波。 地震勘探中,有效波和干扰波是相对的。例如,在反射波…...

7.4.分块查找
一.分块查找的算法思想: 1.实例: 以上述图片的顺序表为例, 该顺序表的数据元素从整体来看是乱序的,但如果把这些数据元素分成一块一块的小区间, 第一个区间[0,1]索引上的数据元素都是小于等于10的, 第二…...

微软PowerBI考试 PL300-选择 Power BI 模型框架【附练习数据】
微软PowerBI考试 PL300-选择 Power BI 模型框架 20 多年来,Microsoft 持续对企业商业智能 (BI) 进行大量投资。 Azure Analysis Services (AAS) 和 SQL Server Analysis Services (SSAS) 基于无数企业使用的成熟的 BI 数据建模技术。 同样的技术也是 Power BI 数据…...
可靠性+灵活性:电力载波技术在楼宇自控中的核心价值
可靠性灵活性:电力载波技术在楼宇自控中的核心价值 在智能楼宇的自动化控制中,电力载波技术(PLC)凭借其独特的优势,正成为构建高效、稳定、灵活系统的核心解决方案。它利用现有电力线路传输数据,无需额外布…...

【SQL学习笔记1】增删改查+多表连接全解析(内附SQL免费在线练习工具)
可以使用Sqliteviz这个网站免费编写sql语句,它能够让用户直接在浏览器内练习SQL的语法,不需要安装任何软件。 链接如下: sqliteviz 注意: 在转写SQL语法时,关键字之间有一个特定的顺序,这个顺序会影响到…...
Linux云原生安全:零信任架构与机密计算
Linux云原生安全:零信任架构与机密计算 构建坚不可摧的云原生防御体系 引言:云原生安全的范式革命 随着云原生技术的普及,安全边界正在从传统的网络边界向工作负载内部转移。Gartner预测,到2025年,零信任架构将成为超…...

Module Federation 和 Native Federation 的比较
前言 Module Federation 是 Webpack 5 引入的微前端架构方案,允许不同独立构建的应用在运行时动态共享模块。 Native Federation 是 Angular 官方基于 Module Federation 理念实现的专为 Angular 优化的微前端方案。 概念解析 Module Federation (模块联邦) Modul…...

Linux-07 ubuntu 的 chrome 启动不了
文章目录 问题原因解决步骤一、卸载旧版chrome二、重新安装chorme三、启动不了,报错如下四、启动不了,解决如下 总结 问题原因 在应用中可以看到chrome,但是打不开(说明:原来的ubuntu系统出问题了,这个是备用的硬盘&a…...

PL0语法,分析器实现!
简介 PL/0 是一种简单的编程语言,通常用于教学编译原理。它的语法结构清晰,功能包括常量定义、变量声明、过程(子程序)定义以及基本的控制结构(如条件语句和循环语句)。 PL/0 语法规范 PL/0 是一种教学用的小型编程语言,由 Niklaus Wirth 设计,用于展示编译原理的核…...