操作系统(三)| 进程管理下 经典进程问题分析 线程 死锁

文章目录

  • 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对此一无所知。 
线程库提供线程创建、撤消、上下文切换、通信、调度等功能。

​ 用户级线程是自己实现的线程创建,删除

​ 但是这样的话操作系统分配的是进程为单位的,容易阻塞

​ 但是性能高,无需陷入内核

核心级线程

​ 用户级线程是自己实现的线程创建,删除

​ 但是这样的话操作系统分配的是线程为单位的

​ 但是性能低,需要陷入内核

进程和线程是操作系统中用于实现并发执行的两个基本概念,它们之间有许多重要区别,包括以下几点:

  1. 定义:

    • 进程(Process)是一个独立的执行单元,拥有独立的内存空间和系统资源,它代表了一个正在运行的程序的实例。每个进程都有自己的地址空间,堆栈和数据段,相互之间不共享这些资源。
    • 线程(Thread)是进程内的一个轻量级执行单元,线程共享进程的地址空间和系统资源,包括堆栈和文件描述符。多个线程可以在同一进程中并发执行,它们之间共享相同的内存空间。
  2. 创建和销毁开销:

    • 进程的创建和销毁通常比较耗费系统资源,因为每个进程都有独立的内存空间,需要进行全新的资源分配和销毁。
    • 线程的创建和销毁相对较轻量,因为它们共享进程的资源。创建一个线程通常比创建一个新进程要快速和经济。
  3. 通信:

    • 进程之间通信通常需要使用进程间通信(Inter-Process Communication,IPC)机制,例如管道、消息队列、共享内存等,来传递数据和信息。
    • 线程之间通信可以更容易地实现,因为它们共享相同的内存空间。线程可以通过共享变量等方式直接进行通信。
  4. 并发性和并行性:

    • 进程通常具有更高的并发性,因为不同进程之间相互独立,可以在不同的处理器上并行执行。多进程可以更好地利用多核处理器。
    • 线程在同一进程内并发执行,它们共享进程的资源,因此在多核处理器上并行执行的程度有限。但线程之间的切换比进程切换更快,因为不涉及进程资源的切换。
  5. 安全性:

    • 由于线程共享进程的内存空间,因此多个线程之间的错误可能更容易导致进程崩溃或数据损坏。
    • 进程之间的安全性更高,因为它们拥有独立的内存空间,一个进程的错误通常不会影响其他进程。
  6. 编程模型:

    • 多进程编程相对较复杂,因为需要处理进程间通信和同步问题。
    • 多线程编程相对较简单,因为线程之间共享数据,但需要小心处理共享资源的同步问题。

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时间

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/160395.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++之常用的排序算法

C之常用的排序算法 sort #include<iostream> using namespace std; #include<vector> #include<algorithm> #include<functional> void Myptint(int val) {cout << val << " "; }void test() {vector<int> v;v.push_back(…

打破应用孤岛,低代码平台效力几何?

关于低代码开发平台&#xff0c;争论有很多。有人认为它是第四代编程语言&#xff0c;有人认为它是开发模式的颠覆&#xff0c;有人认为它是企业管理模式的变革&#xff0c;也有人认为它空有其表。 不过&#xff0c;至少在目前看来&#xff0c;低代码无疑是火爆的&#xff0c;…

整理MLAI学习路径图

干货分享&#xff1a; 下面给出一个笔者自己整理的GitHub仓库&#xff1a;https://github.com/isLinXu/awesome-road-map&#xff0c;里面包含了一些可供参考的学习路径和思维导图&#xff0c;并整理微软、meta、谷歌、Kaggle以及华为、百度、阿里、腾讯、讯飞等相关的学习资源…

一文搞懂什么是 GNU/Linux 操作系统

Author&#xff1a;rab 目录 前言一、UNIX二、Linux三、GNU 前言 你是否经常看见或听说过这么一句话&#xff1a;这是一个类 Unix 的 GNU/Linux 操作系统&#xff0c;你是怎么理解这句话的呢&#xff1f;想要搞懂这句话的含义&#xff0c;你需要了解以下三点基本常识。 一、U…

linux ld 链接器学习笔记

ld链接器笔记 1. 首先编写一段汇编代码 这里的汇编语法时 AT&T语法,是gcc原生支持的语法,底层使用 gas(gnu assembler) 完成汇编,相较于 Intel x86语法, AT&T 语法要更加古老,因此大多数人更加偏向于使用 Intel 的语法. nasm 编译器支持x86语法.自从2.10版本&#xf…

MySQL 事务的底层原理和 MVCC(二)

7.2. undo 日志 7.2.1. 事务回滚的需求 我们说过事务需要保证原子性&#xff0c;也就是事务中的操作要么全部完成&#xff0c;要么什么也不做。但是偏偏有时候事务执行到一半会出现一些情况&#xff0c;比如&#xff1a; 情况一&#xff1a;事务执行过程中可能遇到各种错误&a…

ORB-SLAM3在windows11下的编译使用

01 写在前面 近期在学习SLAM&#xff0c;想部署一下ORB-SLAM3&#xff0c;但是自己电脑是win11系统&#xff0c;因此就想着在win11上部署一下。但是网上看了一些教程&#xff0c;有一些博客&#xff0c;但是可能不适合我这种情况把&#xff0c;就很纠结。先说下结果&#xff0…

【python基础(三)】操作列表:for循环、正确缩进、切片的使用、元组

文章目录 一. 遍历整个列表1. 在for循环中执行更多操作2. 在for循环结束后执行一些操作 二. 避免缩进错误三. 创建数值列表1. 使用函数range()2. 使用range()创建数字列表3. 指定步长。4. 对数字列表执行简单的统计计算5. 列表解析 五. 使用列表的一部分-切片1. 切片2. 遍历切片…

【并发编程】ThreadLocal详解与原理

&#x1f4eb;作者简介&#xff1a;小明Java问道之路&#xff0c;2022年度博客之星全国TOP3&#xff0c;专注于后端、中间件、计算机底层、架构设计演进与稳定性建设优化&#xff0c;文章内容兼具广度、深度、大厂技术方案&#xff0c;对待技术喜欢推理加验证&#xff0c;就职于…

【电路笔记】-电流源

电流源 文章目录 电流源1、概述1.1 理想电流源1.2 实际电流源1.3 连接规则 2、依赖电流2.1 压控电流源2.2 电流控制电流源 3、总结 本文为前面文章 电压源的延续&#xff0c;我们将在本文介绍电流源。 与电压源的情况类似&#xff0c;我们将首先介绍理想电流源的概念&#xff…

MySQL 8.2 Command Line Client打开时一闪而过闪退问题

MySQL8.2安装成功后&#xff0c;发现打开MySQL 8.0 Command Line Client时出现一闪而过&#xff0c;打不开的情况。 解决方案&#xff1a; 1、打开MySQL 8.2 Command Line Client文件位置 2、右键选择属性 3、复制它的目标 4、我复制下来的目标路径是这样的&#xff0c;"…

关于 Docker

关于 Docker 1. 术语Docker Enginedockerd&#xff08;Docker daemon&#xff09;containerdOCI (Open Container Initiative)runcDocker shimCRI (Container Runtime Interface)CRI-O 2. 容器启动过程在 Linux 中的实现daemon 的作用 Docker 是个划时代的开源项目&#xff0c;…

[计算机网络实验]头歌 实验二 以太网帧、IP报文分析(含部分分析)

目录 第1关&#xff1a;Wireshark基本使用入门 【实验目的】 【实验环境】 【本地主机、平台虚拟机之间数据传递】 wireshark基本用法】 1、wireshark主界面 2、抓取分组操作 3、Wireshark窗口功能 4、筛选分组操作 【实验操作】 ​编辑 第2关&#xff1a;Ethernet帧…

编程语言发展史:C++语言的发展和应用

预计更新 第一部分&#xff1a;早期编程语言 1.1布尔代数和机器语言 1.2汇编语言的出现和发展 1.3高级语言的兴起 第二部分&#xff1a;主流编程语言 1.1 C语言的诞生及其影响 1.2 C语言的发展和应用 1.3 Java语言的出现和发展 1.4 Python语言的兴起和特点 1.5 JavaScript语言…

基于Towers of Binary Fields的succinct arguments

1. 引言 Ulvetanna团队Benjamin E. Diamond和Jim Posen 2023年论文《Succinct Arguments over Towers of Binary Fields》&#xff0c;开源代码见&#xff1a; https://github.com/recmo/binius&#xff08;Rust Sage&#xff09;【基于plonky3等库】 在该论文中&#xff1…

Apache POI简介

三十二、Apache POI 32.1 介绍 Apache POI 是一个处理Miscrosoft Office各种文件格式的开源项目。简单来说就是&#xff0c;我们可以使用POI在Java程序中对Miscrosoft Office各种文件进行读写操作。 一般情况下&#xff0c;POI都是用于操作Excel文件。 Apache POI 的应用场…

基于区域划分的GaN HEMT 准物理大信号模型

GaN HEMT器件的大信号等效电路模型分为经验基模型和物理基模型。经验基模型具有较高精度但参数提取困难&#xff0c;特别在GaN HEMT器件工艺不稳定的情况下不易应用。相比之下&#xff0c;物理基模型从器件工作机理出发&#xff0c;参数提取相对方便&#xff0c;且更容易更新和…

火山引擎 ByteHouse 的增强型数据导入技术实践

作为企业数字化建设的必备要素&#xff0c;易用的数据引擎能帮助企业提升数据使用效率&#xff0c;更好提升数据应用价值&#xff0c;夯实数字化建设基础。 数据导入是衡量OLAP引擎性能及易用性的重要标准之一&#xff0c;高效的数据导入能力能够加速数据实时处理和分析的效率。…

Sa-Token 整合Java17和SpringBoot

目录 前言引入项目开启登录认证路由拦截鉴权解决兼容问题总结 前言 之前无意中发现Sa-Token权限认证框架&#xff0c;项目十分好用。 项目地址&#xff1a; https://github.com/dromara/sa-token 官网地址&#xff1a; https://sa-token.cc/doc.html#/start/example 我的个人…

如何轻松应对企业网络管理挑战,释放网络灵活性

企业在日常经营中&#xff0c;越来越依赖于云应用程序&#xff0c;分散的团队和统一通信。这些变化使得保持网络连接性不仅是必要的&#xff0c;而且对任务的成功完成至关重要。 传统的广域网&#xff08;WAN&#xff09;并不总能适应这些挑战&#xff0c;因为它们往往无法提供…