操作系统(三)| 进程管理下 经典进程问题分析 线程 死锁
文章目录
- 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的火爆主要有两个原因。首先,其在人工智能对话技术领域的创新&…...
通过 Taotoken 审计日志功能回溯 API 调用详情与安全事件
通过 Taotoken 审计日志功能回溯 API 调用详情与安全事件 1. 审计日志的核心价值 Taotoken 的审计日志功能为开发者和管理员提供了完整的 API 调用记录。通过这一功能,用户可以清晰地追踪每一次模型调用的详细信息,包括请求时间、响应状态、模型选择、…...
23.树形DP
543. 二叉树的直径 思路 自底向上 当前节点上的逻辑有两个 将左右2条链路拼起来,枚举最优(自己作为转折点)从左右2条中选择一个长的,传给父节点。 代码 124. 二叉树中的最大路径和 思路 和上一题一样 代码...
PixelGen:像素级图像生成架构的创新与实践
1. 项目背景与核心突破PixelGen是我最近在图像生成领域实验的一个创新架构,它通过重新思考扩散模型的计算范式,在像素空间直接实现了比传统潜在扩散模型(LDM)更高质量的图像生成效果。这个项目的起源其实很有意思——当时我正在调…...
端经典面试题:为什么 0.1 + 0.2 !== 0.3?
🧮 前端经典面试题:为什么 0.1 0.2 ! 0.3? 在 JavaScript 控制台中输入以下代码: console.log(0.1 0.2); // 0.30000000000000004 console.log(0.1 0.2 0.3); // false这一刻,很多初学者的世界观崩塌了ÿ…...
从 VS2019 到 OpenSSL:深度解析 EDK2 在 Windows 下的每个依赖项到底在干嘛
从VS2019到OpenSSL:揭秘EDK2开发工具链中每个组件的核心使命 当你在Windows环境下第一次打开EDK2的官方文档,准备搭建UEFI开发环境时,那一长串的依赖项列表可能会让你瞬间头皮发麻——Visual Studio 2019、Python、NASM、LLVM、IASL、OpenSSL…...
FPGA调试利器Manta:基于UART/Ethernet的实时交互与快速原型工具
1. 项目概述:FPGA调试的“瑞士军刀”在FPGA开发的世界里,调试环节往往是最耗时、也最令人头疼的部分。想象一下,你花了几周时间精心设计了一个复杂的数字逻辑模块,烧录到板子上,结果输出信号死活不对。这时候ÿ…...
5分钟掌握Windows安卓应用安装:APK Installer轻量级解决方案揭秘
5分钟掌握Windows安卓应用安装:APK Installer轻量级解决方案揭秘 【免费下载链接】APK-Installer An Android Application Installer for Windows 项目地址: https://gitcode.com/GitHub_Trending/ap/APK-Installer 你是否曾经想在Windows电脑上运行安卓应用…...
Windows系统wlanutil.dll文件丢失找不到无法启动程序解决
在使用电脑系统时经常会出现丢失找不到某些文件的情况,由于很多常用软件都是采用 Microsoft Visual Studio 编写的,所以这类软件的运行需要依赖微软Visual C运行库,比如像 QQ、迅雷、Adobe 软件等等,如果没有安装VC运行库或者安装…...
10分钟快速上手DOL-Lyra:中文美化整合包完整使用指南
10分钟快速上手DOL-Lyra:中文美化整合包完整使用指南 【免费下载链接】DOL-CHS-MODS Degrees of Lewdity 整合 项目地址: https://gitcode.com/gh_mirrors/do/DOL-CHS-MODS 你是否想在《Degrees of Lewdity》游戏中体验完整的中文界面和精美角色美化…...
CATIA新手必看:解决零件变暗、命令不连续等12个高频‘卡点’的保姆级教程
CATIA新手避坑指南:12个高频问题的一键解决方案 刚接触CATIA的设计师们,是否经常被一些看似简单却让人抓狂的小问题绊住脚步?明明是个功能强大的三维设计软件,却总在基础操作上栽跟头。本文将针对12个最常见的新手"卡点"…...
