当前位置: 首页 > news >正文

软考中级-操作系统

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 操作系统地位计算机系统由硬件和软件组成&#xff0c;未配置软件的称为裸机&#xff0c;但这会导致效率低下。操作系统是为弥补用户与硬件之间的鸿沟的一种系统软件&#xff0c;汇编、编译、解释、数据库管理系统等系统软件和其他应用软件都在此基础。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仓库&#xff0c;该仓库包含计算机基础、Java基础、多线程、JVM、数据库、Redis、Spring、Mybatis、SpringMVC、SpringBoot、分布式、微服务、设计模式、架构、校招社招分享等核心知识点&#xff0c;欢迎star~ Github地址&#xff1a;https://github.com/…...

Spring Cloud Alibaba全家桶(二)——微服务组件Nacos注册中心

前言 本文为微服务组件Nacos注册中心相关知识&#xff0c;下边将对什么是 Nacos&#xff0c;Nacos注册中心&#xff08;包括&#xff1a;注册中心演变及其设计思想、核心功能&#xff09;&#xff0c;Nacos Server部署&#xff08;包括&#xff1a;单机模式、集群模式&#xff…...

命令执行漏洞 | 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自动机 该模型应用场景是什么样的&#xff1f;假如有一篇很长的文章&#xff0c;然后有一个敏感词表单&#xff0c;请从这篇文章里找出包含了哪些敏感词。即便是用KMP进行快速匹配&#xff0c;那也只能每次遍历整篇文章才能找到一种敏感词&#xff0c;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 克隆&#xff08;clone&#xff09; 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>③群魔乱舞&#xff08;这是错…...

Linux系统下搭建maven环境

文章目录前述从官网下载安装包安装 maven修改maven配置修改环境变量测试前述 安装 maven 环境前&#xff0c;需要先安装 java 环境&#xff0c;如果没有安装 java 环境&#xff0c;可以参考&#xff1a;https://blog.csdn.net/weixin_45583303/article/details/118631855 从官…...

English Learning - L2 语音作业打卡 Day3 2023.2.23 周四

English Learning - L2 语音作业打卡 Day3 2023.2.23 周四&#x1f48c; 发音小贴士&#xff1a;&#x1f48c; 当日目标音发音规则/技巧&#xff1a;&#x1f36d; Part 1【热身练习】&#x1f36d; Part2【练习内容】&#x1f36d;【练习感受】&#x1f353;元音[ ɔ: ]&…...

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)

声明&#xff1a;本文仅为个人学习记录所用&#xff0c;参考较多&#xff0c;如有侵权&#xff0c;联系删除 决策树 通俗来说&#xff0c;决策树分类的思想类似于找对象。现想象一个女孩的母亲要给这个女孩介绍男朋友&#xff0c;于是有了下面的对话&#xff1a; 女儿&#x…...

软件测试之因果图法

因果图法 1. 概述 因果图法是一种**利用图解法分析输入条件、输出结果的各种组合情况,**从而设计测试用例的方法. 因果图法适用于有多个输入和多个输出&#xff0c;而且输入和输入之间有相互的组合关系&#xff0c;输入和输出之间有相互的制约和依赖关系. 使用场景和判定表…...

vue中子组件间接修改父组件传递过来的值

一、前言 Vue官方文档Props单向数据流讲解 Vue中遵循单向数据流&#xff0c;所有的 props 都遵循着单向绑定原则&#xff0c;props 因父组件的更新而变化&#xff0c;自然地将新的状态向下流往子组件&#xff0c;而不会逆向传递。这避免了子组件意外修改父组件的状态的情况&a…...

Java I/O

前言 关于IO, 想必你听过很多中I/O方式, 有的是OS视角的, 有的是JDK本身支持的, 有的是纯实现视角。但是作为一个developer, 我希望你能先搞清楚上下文之后, 再去理解内容, 否则容易抬杠。这个上下文有横向和纵向两个维度。纵向维度包括JDK底层, JDK上层包装库, 开发框架(如Ne…...

R语言AI模型部署方案:精准离线运行详解

R语言AI模型部署方案:精准离线运行详解 一、项目概述 本文将构建一个完整的R语言AI部署解决方案,实现鸢尾花分类模型的训练、保存、离线部署和预测功能。核心特点: 100%离线运行能力自包含环境依赖生产级错误处理跨平台兼容性模型版本管理# 文件结构说明 Iris_AI_Deployme…...

聊聊 Pulsar:Producer 源码解析

一、前言 Apache Pulsar 是一个企业级的开源分布式消息传递平台&#xff0c;以其高性能、可扩展性和存储计算分离架构在消息队列和流处理领域独树一帜。在 Pulsar 的核心架构中&#xff0c;Producer&#xff08;生产者&#xff09; 是连接客户端应用与消息队列的第一步。生产者…...

代理篇12|深入理解 Vite中的Proxy接口代理配置

在前端开发中,常常会遇到 跨域请求接口 的情况。为了解决这个问题,Vite 和 Webpack 都提供了 proxy 代理功能,用于将本地开发请求转发到后端服务器。 什么是代理(proxy)? 代理是在开发过程中,前端项目通过开发服务器,将指定的请求“转发”到真实的后端服务器,从而绕…...

关键领域软件测试的突围之路:如何破解安全与效率的平衡难题

在数字化浪潮席卷全球的今天&#xff0c;软件系统已成为国家关键领域的核心战斗力。不同于普通商业软件&#xff0c;这些承载着国家安全使命的软件系统面临着前所未有的质量挑战——如何在确保绝对安全的前提下&#xff0c;实现高效测试与快速迭代&#xff1f;这一命题正考验着…...

Java + Spring Boot + Mybatis 实现批量插入

在 Java 中使用 Spring Boot 和 MyBatis 实现批量插入可以通过以下步骤完成。这里提供两种常用方法&#xff1a;使用 MyBatis 的 <foreach> 标签和批处理模式&#xff08;ExecutorType.BATCH&#xff09;。 方法一&#xff1a;使用 XML 的 <foreach> 标签&#xff…...

视觉slam十四讲实践部分记录——ch2、ch3

ch2 一、使用g++编译.cpp为可执行文件并运行(P30) g++ helloSLAM.cpp ./a.out运行 二、使用cmake编译 mkdir build cd build cmake .. makeCMakeCache.txt 文件仍然指向旧的目录。这表明在源代码目录中可能还存在旧的 CMakeCache.txt 文件,或者在构建过程中仍然引用了旧的路…...

A2A JS SDK 完整教程:快速入门指南

目录 什么是 A2A JS SDK?A2A JS 安装与设置A2A JS 核心概念创建你的第一个 A2A JS 代理A2A JS 服务端开发A2A JS 客户端使用A2A JS 高级特性A2A JS 最佳实践A2A JS 故障排除 什么是 A2A JS SDK? A2A JS SDK 是一个专为 JavaScript/TypeScript 开发者设计的强大库&#xff…...

多模态图像修复系统:基于深度学习的图片修复实现

多模态图像修复系统:基于深度学习的图片修复实现 1. 系统概述 本系统使用多模态大模型(Stable Diffusion Inpainting)实现图像修复功能,结合文本描述和图片输入,对指定区域进行内容修复。系统包含完整的数据处理、模型训练、推理部署流程。 import torch import numpy …...

uniapp 实现腾讯云IM群文件上传下载功能

UniApp 集成腾讯云IM实现群文件上传下载功能全攻略 一、功能背景与技术选型 在团队协作场景中&#xff0c;群文件共享是核心需求之一。本文将介绍如何基于腾讯云IMCOS&#xff0c;在uniapp中实现&#xff1a; 群内文件上传/下载文件元数据管理下载进度追踪跨平台文件预览 二…...

基于鸿蒙(HarmonyOS5)的打车小程序

1. 开发环境准备 安装DevEco Studio (鸿蒙官方IDE)配置HarmonyOS SDK申请开发者账号和必要的API密钥 2. 项目结构设计 ├── entry │ ├── src │ │ ├── main │ │ │ ├── ets │ │ │ │ ├── pages │ │ │ │ │ ├── H…...