操作系统(三)| 进程管理下 经典进程问题分析 线程 死锁
文章目录
- 6.经典进程同步问题
- 6.1 生产者-消费者问题 (既有同步又有互斥)
- 6.2 读者-写者问题
- 6.3 哲学家进餐问题
- 6.4理发师问题
- 7. 进程之间通信
- 7.1 共享存储区
- 7.2 消息传递
- 7.3 管道
- 8.线程
- 8.1 线程的实现机制
- 9 进程调度
- 9.1 调度方式
- 9.2 常见算法
- 先来先服务 FCFS
- 短进程优先 SPN
- 最高相应比优先算法
- 时间片轮转 RR
- 基于优先级的调度
- 多级反馈队列
- 10 死锁
- 10.1 基本概念
- 资源分类
- 10.2 如何处理死锁
- 10.2.1 死锁检测
- 10.2.2 何时检测
6.经典进程同步问题
6.1 生产者-消费者问题 (既有同步又有互斥)
生产者往缓冲区写数据,满了的话就不能写了
消费者从缓冲区取数据,空的话就不能取了
一次只能有一个生产者或消费者取读数据
总结要求
(1)不能向满的缓存区写数据
(2)不能向空的缓存区取数据
(3)任何时刻,仅允许一个1个生成者或1个消费者访问
意味着消费者之间互斥,生成者之间互斥,消费者和生产者之间互斥
full:记录缓冲区中非空的槽数,初始值=0
empty:记录缓冲区中空的槽数,初始值=N
mutex:确保进程不同时访问缓冲区,初始值=1
解决(1)(2)
void producer(void){while (True) {produce(); //生产1项P(empty); //申请1个空槽P(mutex); //请求进入临界区append(); //加入缓冲区V(mutex); //离开临界区V(full); //递增非空槽}
}void consumer(void){while (TRUE) {P(full); //申请1个非空槽P(mutex); //申请进入临界区remove(); //从缓冲区移出1项V(mutex); //离开临界区V(empty); //递增空槽数consume(); //消费数据}
}
解决死锁问题
6.2 读者-写者问题
多个Reader进程,多个Writer进程,共享文件F
要求:
允许多个Reader进程同时读文件
不允许任何一个Writer进程与其他进程同时访问(读或写)文件
我的方案
read_count=N 初始值N,空额的值
write_count=0
void reader(void){while (True) {P(read_count)if(writer==0)read();//读操作V(read_count)P(write_count)read();V(write_count)}
}void writer(void){while (True) {P(write_count)write();V(write_count)}
}
标答
write
WriteMutex = 0 读写操作的互斥访问
Rcoun = 0 正在读操作的读者数目
CountMutex = 0 读者计数的互斥访问
void reader(void){while (True) {P(CountMutex);if (Rcount == 0)P(WriteMutex);++Rcount;V(CountMutex);read;P(CountMutex);--Rcount;if (Rcount == 0)V(WriteMutex);V(CountMutex);}
}void writer(void){while (True) {P(WriteMutex);write;V(WriteMutex);}
}
6.3 哲学家进餐问题
6.4理发师问题
注意对于共享变量,一定要加PV临界操作
7. 进程之间通信
P,V操作实现的是进程之间的低级通信,所以P,V操作是低级通讯原语,即不能传递大量的信息
所以我们引入进程间高级通讯方式
7.1 共享存储区
相互通信的进程间设有公共的内存区,每个进程既可向该公共内存中写,也可从公共内存中读,通过这种方式实现进程间的信息交换。
把同一个物理内存区域同时映射到多个进程的内存地址空间的通信机制
7.2 消息传递
源进程发送消息,目的进程接受消息。所谓消息,就是一组数据。
(1)消息队列(message Queue)或消息缓冲
发送者发消息到一个消息队列中;
接收者从相应的消息队列中取消息。
消息队列所占的空间从系统的公用缓冲区中申请得到。
(2)邮箱(mailbox)
发送者发消息到邮箱,接收者从邮箱取消息。
邮箱是一种中间实体,一般用于非实时通信。
7.3 管道
首创于Unix。用于连接一个读进程、一个写进程,以实现它们之间通信的共享文件,称为pipe文件。
管道分为下列2种:
有名管道
无名管道
8.线程
为什么引入线程
线程是进程的1条执行路径。
1个进程可以有多个线程,其中至少有1个主线程(primary thread)。
1个进程内的多个线程在同一个地址空间内(共享该进程的地址空间)。
每个线程有自己的线程控制块TCB(Thread Control Block),包含自己的堆栈和状态信息。TCB比PCB小得多。
8.1 线程的实现机制
用户级线程
由在用户空间执行的线程库来实现,OS对此一无所知。
线程库提供线程创建、撤消、上下文切换、通信、调度等功能。
用户级线程是自己实现的线程创建,删除
但是这样的话操作系统分配的是进程为单位的,容易阻塞
但是性能高,无需陷入内核
核心级线程
用户级线程是自己实现的线程创建,删除
但是这样的话操作系统分配的是线程为单位的
但是性能低,需要陷入内核
进程和线程是操作系统中用于实现并发执行的两个基本概念,它们之间有许多重要区别,包括以下几点:
-
定义:
- 进程(Process)是一个独立的执行单元,拥有独立的内存空间和系统资源,它代表了一个正在运行的程序的实例。每个进程都有自己的地址空间,堆栈和数据段,相互之间不共享这些资源。
- 线程(Thread)是进程内的一个轻量级执行单元,线程共享进程的地址空间和系统资源,包括堆栈和文件描述符。多个线程可以在同一进程中并发执行,它们之间共享相同的内存空间。
-
创建和销毁开销:
- 进程的创建和销毁通常比较耗费系统资源,因为每个进程都有独立的内存空间,需要进行全新的资源分配和销毁。
- 线程的创建和销毁相对较轻量,因为它们共享进程的资源。创建一个线程通常比创建一个新进程要快速和经济。
-
通信:
- 进程之间通信通常需要使用进程间通信(Inter-Process Communication,IPC)机制,例如管道、消息队列、共享内存等,来传递数据和信息。
- 线程之间通信可以更容易地实现,因为它们共享相同的内存空间。线程可以通过共享变量等方式直接进行通信。
-
并发性和并行性:
- 进程通常具有更高的并发性,因为不同进程之间相互独立,可以在不同的处理器上并行执行。多进程可以更好地利用多核处理器。
- 线程在同一进程内并发执行,它们共享进程的资源,因此在多核处理器上并行执行的程度有限。但线程之间的切换比进程切换更快,因为不涉及进程资源的切换。
-
安全性:
- 由于线程共享进程的内存空间,因此多个线程之间的错误可能更容易导致进程崩溃或数据损坏。
- 进程之间的安全性更高,因为它们拥有独立的内存空间,一个进程的错误通常不会影响其他进程。
-
编程模型:
- 多进程编程相对较复杂,因为需要处理进程间通信和同步问题。
- 多线程编程相对较简单,因为线程之间共享数据,但需要小心处理共享资源的同步问题。
9 进程调度
为什么进程调度
多个进程就绪时候,OS决定先执行哪一个
我们进程调度要达到的目的
CPU利用率高,吞吐量大,周转时间少,等待时间短,公平
很多时候都是在权衡!很多时候很难兼顾所有的目的
什么时候会切换进程呢?
硬件中断,进程异常,或者该进程请求IO,这些都会让CPU闲下来,我们就要给CPU找活干了
一些概念
- 周转时间 = 作业完成时刻 - 作业到达时刻
- 带权周转时间 = 周转时间 / 服务时间
- 平均周转时间 = 作业周转总时间 / 作业个数
- 平均带权周转时间 = 带权周转总时间 / 作业个数
9.1 调度方式
非抢占方式
一旦某进程被调度,直到完成或因某事件而阻塞,才会切换到其他进程
抢占方式
允许暂停正在运行的进程,切换到其他进程
抢占原则:
时间片原则:时间片到时抢占
优先级原则:优先级高者到时抢占
9.2 常见算法
先来先服务 FCFS
按照进程就绪的先后次序来调度进程,非抢占式方式
优点:实现简单
缺点:
(1)平均等待时间波动很大
短进程、长进程到达时间是随机的
(2)有利于CPU繁忙型进程,不利于I/O繁忙型进程
(3)有利于长进程,不利于短进程
短进程优先 SPN
最高相应比优先算法
时间片轮转 RR
将所有的就绪进程按FCFS原则排成一个队列,
规定一个时间片为进程每次使用CPU的最长时间,
每次选择队首进程运行,
当时间片到时,剥夺该进程的运行,将其排在队尾
基于优先级的调度
多级反馈队列
10 死锁
10.1 基本概念
死锁
一个进程集合中的每个进程都在等待只能由该集合中的其它进程才能引发的事件,这种状态称作死锁。一组竞争系统资源的进程由于相互等待而出现“永久”阻塞。
例如,2个进程A、B,都需要资源R1、R2
若A:拥有R1,申请R2
若B:拥有R2,申请R1
如何?
资源分类
可重用资源
资源不能被删除且在任何时刻只能有一个进程使用
进程释放资源后,其他进程可重用
消耗资源
10.2 如何处理死锁
由OS处理
检测死锁并恢复
分配资源时避免死锁
假装没看见(鸵鸟策略):多数OS对待死锁的策略
死锁了怎么办,开机重启
由应用程序本身预防死锁
实际中检测死锁恢复是可能的,但是代价太大
10.2.1 死锁检测
E[M]:总资源数;E[i]:资源i的个数
A[M]:当前可用资源数;A[i]:资源i的可用数
C[N][M]:当前分配矩阵;C[i][j]:进程i对资源j的占有数
第i行是进程i当前占有的资源数
R[N][M]:申请矩阵;R[i][j]:进程i对资源j的申请数
第i行是进程i申请的资源数
F[N]:进程标记;F[i]取0/1,为1表示进程i能够执行
算法
看当前是否有进程可以执行,可以执行的话,该进程F[N]设置为1,同时释放他的资源
依次进行
两种情况
一, 所有进程都可以执行,则不死锁
二,存在某一种情况所有的进程都无法执行,则死锁
10.2.2 何时检测
1)每当有资源请求时;
2)周期性检测;
3)每当CPU的使用率降到某一阈值时。
死锁检测会占用大量的CPU时间
相关文章:
操作系统(三)| 进程管理下 经典进程问题分析 线程 死锁
文章目录 6.经典进程同步问题6.1 生产者-消费者问题 (既有同步又有互斥)6.2 读者-写者问题6.3 哲学家进餐问题6.4理发师问题 7. 进程之间通信7.1 共享存储区7.2 消息传递7.3 管道 8.线程8.1 线程的实现机制 9 进程调度9.1 调度方式9.2 常见算法先来先服务 FCFS短进程优先 SPN最…...
vue3使用tsx自定义弹窗组件
1.在ts代码中使用css 我这里使用了styils/vue,npm install styils/vue --save-dev,在tsx文件中引入即可:import { styled } from "styils/vue"; 2.在tsx中初始化组件,创建在src的utils目录中创建messagebox.tsx impo…...
[笔记] 错排问题 #错排
参考:刷题笔记-错排问题总结 错排问题: 一个n个元素的排列,若一个排列中所有的元素都不在自己原来的位置上,那么这样的一个排列就称为原排列的一个错排。而研究一个排列的错排个数的问题,就称为错排问题(或…...
Ajax进阶
前后端传输数据的编码格式(contentType) # 提示: 主要研究post请求数据的编码格式.get请求数据就是直接放在url?号后面的每个参数之间用&符连接, 如下:url?usernamejason&password123 # 可以朝后端发送post请求的方式1 .form表单2. ajax请求# 基于post请求. 前后端传…...
RedisTemplate使用详解
RedisTemplate介绍StringRedisTemplate介绍RedisConnectionFactory介绍RedisConnectionFactory源码解析 RedisOperations介绍RedisOperations源码解析 RedisTemplate使用连接池配置RedisTemplate连接池连接池配置 RedisTemplate应用场景RedisTemplate主要特点RedisTemplate使用…...
6.Gin 路由详解 - GET POST 请求以及参数获取示例
6.Gin 路由详解 - GET POST 请求以及参数获取示例 GET POST 请求以及参数获取示例 Get 请求:获取 Quary 参数 // 获取query参数示例:GET /user?uid20&namejack&page1 r.GET("/user", func(c *gin.Context) {// 获取参数// Query获取参…...
CMakeLists.txt基础指令与cmake-gui生成VS项目的步骤
简介 本博客主要介绍cmake的基本指令,同时,很多使用Visual Studio小白从Gitbub下载项目源码后,看到CMakeLists.txt,不知道如何使用Visual Studio编译源码;针对以上问题,做一下简单操作与解释,方…...
IT应用运维最常用指标
可用性(Availability) 系统或服务在特定时间范围内可用的百分比。 计算方式:(总时间 - 不可用时间)/ 总时间 * 100%。 参考值:99.9%。 应用范围:应用系统、网络设备。 故障率(Fa…...
Go中各种newreader和newbuffer的使用
一、bytes.NewBuffer和bytes.NewReader func main() {var byteArr []bytebuf : bytes.NewBuffer(byteArr)buf.Write([]byte("今天不错"))fmt.Println(buf.String()) }package mainimport ("bytes""fmt" )func main() {data : []byte("路多…...
visual studio 如何建立 C 语言项目
安装这个 模块。 新建 空项目 创建完成 写demo 点击运行:...
app小程序定制开发的优势|企业软件网站建设
app小程序定制开发的优势|企业软件网站建设 小程序定制开发是目前互联网行业中备受关注的领域之一。随着智能手机的普及和移动互联网的迅猛发展,越来越多的企业和个人开始重视小程序的潜力,并积极寻求定制开发的服务。那么,为什么小程序定制开…...
物联网AI MicroPython学习之语法 WDT看门狗外设
学物联网,来万物简单IoT物联网!! WDT 介绍 模块功能: 看门狗WDT(WatchDog Timer)外设驱动模块 接口说明 WDT - 构建WDT对象 函数原型:WDT(timeout)参数说明: 参数类型必选参数?…...
JVM线程的几种状态
1.New 新建的线程,线程还没启动。 2.Runnable 线程正在运行或者等待操作系统中的其他资源,例如线程运行过程中,系统分配资源给其他操作,此时这个线程还是Runnable状态,可以理解为可运行的线程。 3.Blocked 阻塞状…...
基于单片机停车场环境监测系统仿真设计
**单片机设计介绍, 基于单片机停车场环境监测系统仿真设计 文章目录 一 概要二、功能设计设计思路 三、 软件设计原理图 五、 程序六、 文章目录 一 概要 基于单片机的停车场环境监测系统是一种利用单片机技术实现环境监测和数据处理的系统。它可以感知停车场的温湿…...
每日一题:LeetCode-589.N叉树的前序遍历
每日一题系列(day 01) 前言: 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🔎…...
PTA 7-2 简单计算器
7-2 简单计算器 分数 20 全屏浏览题目 作者 张彤彧 单位 浙江大学 模拟简单运算器的工作。假设计算器只能进行加减乘除运算,运算数和结果都是整数,四种运算符的优先级相同,按从左到右的顺序计算。 输入格式: 输入在一行中给出一个四则运…...
9、鸿蒙应用桌面图标外观和国际化
一、项目资源目录 项目下的resoueces目录为资源配置目录,其中base为基础配置,即在任何语言环境下都会加载的资源, color.json:用于配置颜色,如页面的背景和文字的颜色。 string.json:用于设置文字&#…...
oracle rac 19c修改不同网段public ip
客户需求将才搭建的oracle 19.19数据库从192.168.168.0网段调整到192.168.213网段 1.停止两个节点集群 停止之前最好ocrdump一下,防止有问题 crsctl stop crs 2.修改public ip地址和/etc/hosts 3. 启动crs 这时集群可以启动,但是上面的一些资源启动会…...
【Django-DRF用法】多年积累md笔记,第(4)篇:Django-DRF反序列化详解
本文从分析现在流行的前后端分离Web应用模式说起,然后介绍如何设计REST API,通过使用Django来实现一个REST API为例,明确后端开发REST API要做的最核心工作,然后介绍Django REST framework能帮助我们简化开发REST API的工作。 全…...
OpenAI宣布暂停ChatGPT plus用户订阅,解决方案,无需等待立马升级
作为人工智能领域的一项重要革新,ChatGPT Plus的上线引起了众多用户的关注,其背后的OpenAI表现出傲娇的态度,被誉为下一个GTP 4.0。总的来说,ChatGPT Plus的火爆主要有两个原因。首先,其在人工智能对话技术领域的创新&…...
从深圳崛起的“机器之眼”:赴港乐动机器人的万亿赛道赶考路
进入2025年以来,尽管围绕人形机器人、具身智能等机器人赛道的质疑声不断,但全球市场热度依然高涨,入局者持续增加。 以国内市场为例,天眼查专业版数据显示,截至5月底,我国现存在业、存续状态的机器人相关企…...
Golang dig框架与GraphQL的完美结合
将 Go 的 Dig 依赖注入框架与 GraphQL 结合使用,可以显著提升应用程序的可维护性、可测试性以及灵活性。 Dig 是一个强大的依赖注入容器,能够帮助开发者更好地管理复杂的依赖关系,而 GraphQL 则是一种用于 API 的查询语言,能够提…...
鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个生活电费的缴纳和查询小程序
一、项目初始化与配置 1. 创建项目 ohpm init harmony/utility-payment-app 2. 配置权限 // module.json5 {"requestPermissions": [{"name": "ohos.permission.INTERNET"},{"name": "ohos.permission.GET_NETWORK_INFO"…...
使用 SymPy 进行向量和矩阵的高级操作
在科学计算和工程领域,向量和矩阵操作是解决问题的核心技能之一。Python 的 SymPy 库提供了强大的符号计算功能,能够高效地处理向量和矩阵的各种操作。本文将深入探讨如何使用 SymPy 进行向量和矩阵的创建、合并以及维度拓展等操作,并通过具体…...
招商蛇口 | 执笔CID,启幕低密生活新境
作为中国城市生长的力量,招商蛇口以“美好生活承载者”为使命,深耕全球111座城市,以央企担当匠造时代理想人居。从深圳湾的开拓基因到西安高新CID的战略落子,招商蛇口始终与城市发展同频共振,以建筑诠释对土地与生活的…...
【JVM】Java虚拟机(二)——垃圾回收
目录 一、如何判断对象可以回收 (一)引用计数法 (二)可达性分析算法 二、垃圾回收算法 (一)标记清除 (二)标记整理 (三)复制 (四ÿ…...
安卓基础(Java 和 Gradle 版本)
1. 设置项目的 JDK 版本 方法1:通过 Project Structure File → Project Structure... (或按 CtrlAltShiftS) 左侧选择 SDK Location 在 Gradle Settings 部分,设置 Gradle JDK 方法2:通过 Settings File → Settings... (或 CtrlAltS)…...
SQL Server 触发器调用存储过程实现发送 HTTP 请求
文章目录 需求分析解决第 1 步:前置条件,启用 OLE 自动化方式 1:使用 SQL 实现启用 OLE 自动化方式 2:Sql Server 2005启动OLE自动化方式 3:Sql Server 2008启动OLE自动化第 2 步:创建存储过程第 3 步:创建触发器扩展 - 如何调试?第 1 步:登录 SQL Server 2008第 2 步…...
WEB3全栈开发——面试专业技能点P7前端与链上集成
一、Next.js技术栈 ✅ 概念介绍 Next.js 是一个基于 React 的 服务端渲染(SSR)与静态网站生成(SSG) 框架,由 Vercel 开发。它简化了构建生产级 React 应用的过程,并内置了很多特性: ✅ 文件系…...
基于单片机的宠物屋智能系统设计与实现(论文+源码)
本设计基于单片机的宠物屋智能系统核心是实现对宠物生活环境及状态的智能管理。系统以单片机为中枢,连接红外测温传感器,可实时精准捕捉宠物体温变化,以便及时发现健康异常;水位检测传感器时刻监测饮用水余量,防止宠物…...
