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

操作系统篇--八股文学习第十一天|进程调度算法你了解多少,进程间有哪些通信方式,解释一下进程同步和互斥,以及如何实现进程同步和互斥

进程调度算法你了解多少?

答: 

  1. 先来先服务:按照请求的顺序进行调度。 这种调度方式简单,但是能导致较长作业阻塞较短作业。
  2. 最短作业优先:非抢占式的调度算法,按估计运行时间最短的顺序进行调度。 但是如果一直有短作业到来,那么长作业永远得不到调度,造成长作业“饥饿”现象。
  3. 最短剩余时间优先:基于最短作业优先改进,按剩余运行时间的顺序进行调度。当一个新的作业到达时,其整个运行时间与当前进程的剩余时间作比较。如果新的进程需要的时间更少,则挂起当前进程,运行新的进程。否则新的进程等待。
  4. 优先级调度:为每个进程分配一个优先级,按优先级进行调度。为了防止低优先级的进程永远等不到调度,可以随着时间的推移增加等待进程的优先级。
  5. 时间片轮转:为每个进程分配一个时间片,进程轮流执行,时间片用完后切换到下一个进程。

多级反馈队列:融合了时间片轮转调度算法和优先级调度算法,通过动态调整进程的优先级和时间片大小,多级反馈队列调度算法可以兼顾多方面的系统目标
多级反馈队列调度算法的实现思想如下:

  • 设置多个就绪队列,并为每个队列赋予不同的优先级。第1级队列的优先级最高,第2级队列的优先级次之。其余队列的优先级逐个降低。
  • 赋予各个队列的进程运行时间片的大小各不相同。在优先级越高的队列中,每个进程的时间片就越小。例如,第 i+1级队列的时间片要比第i级队列的时间片长1倍。
  • 每个队列都采用FCFS算法。当新进程进入内存后,首先将它放入第1级队列的未尾,按FCFS原则等待调度。当轮到该进程执行时,如它能在该时间片内完成,便可撤离系统。若它在一个时间片结束时尚未完成,调度程序将其转入第2级队列的未尾等待调度:若它在第2级队列中运行一个时间片后仍未完成,再将它放入第3级队列.,依此类推。当进程最后被降到第n级队列后,在第n级队列中便采用时间片轮转方式运行。
  • 按队列优先级调度。仅当第1级队列为空时,才调度第2级队列中的进程运行;仅当第 1~i-1级队列均为空时,才会调度第i级队列中的进程运行。若处理机正在执行第i级队列中的某进程时,又有新进程进入任一优先级较高的队列,此时须立即把正在运行的进程放回到第级队列的未尾,而把处理机分配给新到的高优先级进程。

进程间有哪些通信方式?

答: 

  1. 管道:是一种半双工的通信方式,数据只能单向流动而且只能在具有父子进程关系的进程间使用。
  2. 命名管道: 类似管道,也是半双工的通信方式,但是它允许在不相关的进程间通信。
  3. 消息队列:允许进程发送和接收消息,而消息队列是消息的链表,可以设置消息优先级。
  4. 信号:用于发送通知到进程,告知其发生了某种事件或条件。
  5. 信号量:是一个计数器,可以用来控制多个进程对共享资源的访问,常作为一种锁机制,防止某进程正在访问共享资源时,其他进程也访问该资源。因此主要作为进程间以及同一进程内不同线程之间的同步手段。
  6. 共享内存:就是映射一段能被其他进程所访问的内存,这段共享内存由一个进程创建,但多个进程都可以访问。共享内存是最快的进程通信方式,
  7. Socket套接字:是支持TCP/IP 的网络通信的基本操作单元,主要用于在客户端和服务器之间通过网络进行通信。

解释一下进程同步和互斥,以及如何实现进程同步和互斥?

答:

进程同步是指多个并发执行的进程之间协调和管理它们的执行顺序,以确保它们按照一定的顺序或时间间隔执行。

互斥指的是在某一时刻只允许一个进程访问某个共享资源。当一个进程正在使用共享资源时,其他进程不能同时访问该资源。

解决进程同步和互斥的问题有很多种方法,其中一种常见的方法是使用信号量和 PV 操作。信号量是一种特殊的变量,它表示系统中某种资源的数量或者状态。PV 操作是一种对信号量进行增加或者减少的操作,它们可以用来控制进程之间的同步或者互斥。

  • P操作:相当于“检查”信号量,如果资源可用,就减少计数,然后使用资源。
  • V操作:相当于“归还”资源,增加信号量的计数,并可能唤醒等待的进程。

除此之外,下面的方法也可以解决进程同步和互斥问题:

  • 临界区:将可能引发互斥问题的代码段称为临界区,里面包含了需要互斥访问的资源。进入这个区域前需要先获取锁,退出临界区后释放该锁。这确保同一时间只有一个进程可以进入临界区。
  • 互斥锁(Mutex):互斥锁是一种同步机制,用于实现互斥。每个共享资源都关联一个互斥锁,进程在访问该资源前需要先获取互斥锁,使用完后释放锁。只有获得锁的进程才能访问共享资源。
  • 条件变量:条件变量用于在进程之间传递信息,以便它们在特定条件下等待或唤醒。通常与互斥锁一起使用,以确保等待和唤醒的操作在正确的时机执行。

相关文章:

操作系统篇--八股文学习第十一天|进程调度算法你了解多少,进程间有哪些通信方式,解释一下进程同步和互斥,以及如何实现进程同步和互斥

进程调度算法你了解多少? 答: 先来先服务:按照请求的顺序进行调度。 这种调度方式简单,但是能导致较长作业阻塞较短作业。最短作业优先:非抢占式的调度算法,按估计运行时间最短的顺序进行调度。 但是如果…...

慢慢欣赏arm64内核启动6 primary_entry之el2_setup代码第三部分

分析代码 解析完虚拟化部分,我们继续分析启动过程中,对中断控制器的处理 #ifdef CONFIG_ARM_GIC_V3/* GICv3 system register access */mrs x0, id_aa64pfr0_el1ubfx x0, x0, #ID_AA64PFR0_GIC_SHIFT, #4cbz x0, 3fmrs_s x0, SYS_ICC_SRE_EL2orr x0, x…...

初谈Linux多线程--线程控制

文章目录 线程的概述理解线程Linux中的线程重新理解的进程Windows的线程线程的优点线程的缺点理解线程调度成本低 进程VS线程 线程控制创建线程等待线程线程函数传参线程的返回值新线程的返回值新线程返回值错误返回值为类对象 创建多线程线程的终止线程的分离pthread_detach 线…...

文件工具类 - FileUtils

Slf4j Component public class FileUtils {/*** 文件夹复制到指定的文件夹*/SneakyThrowspublic static void copyDir(File source, File target) {if (!target.exists()) {boolean mkdirs target.mkdirs();}if (source.isDirectory()) {File[] files source.listFiles();if …...

Kafka源码剖析-Producer基于内存缓存池分配ByteBuffer

文章目录 在将消息发送到内存缓中区之前做的准备工作发送消息前的准备工作代码示例源码分析1. **消息序列化**2. **元数据准备**3. **分区选择**4. **批处理准备**总结大致浏览一下源码中将消息写入内存缓冲的运行流程源码分析1. **消息序列化和创建记录批次**2. **确定分区**3…...

实习十九:学习笔记

上午 1、构建vue发行版本 [rootserver ~]# cd eleme_web/ [rootserver eleme_web]# npm run buid //项目未执行时运行该命令,创建发行版本 [rootserver eleme_web]# cd dist/ //dist中包含发行版本的所有文件 [rootserver dist]# ls css favicon.ico i…...

OrionX:革新GPU资源管理,助力AI开发团队高效运作

您的AI开发团队是否经常陷入这样的窘境: 人多卡少,GPU资源难以满足每个成员的需求? 当开发环境中需要变更GPU卡配置时,流程繁琐不堪,不得不关闭容器、重新配置再重启? 是否曾因GPU卡分配后未被充分利用而…...

RabbitMQ发送者重连、发送者确认

RabbitMQ发送者重连、发送者确认 一、发送者重连 spring:rabbitmq:connection-timeout: 1s #设置MQ的连接超时时间template:retry:enabled: true #开启超时重试机制initial-interval: 1000ms #失败后的初始等待时间multiplier: 1 #失败后下次的等待时长倍数,下次等…...

请转告HPC计算AI计算单位,选对存储事半功倍

U.2 NVMe全闪混合统一存储GS 5000U是Infortrend产品中一款高性能机型。得益于搭载强劲的第五代IntelXeon处理器,以及支持PCIe 5.0、NVMe-oF、100GbE等多种特点,GS 5000U单台块级性能可达50 GB/s的读、20 GB/s的写,以及1300K的IOPS&#xff1b…...

[GYCTF2020]Blacklist1

打开题目 判断注入类型,输入1试试 输入2 输入1 判断为字符型注入 堆叠查询2;show databases;# 然后来输入2; show tables;#来查看数据库的表 然后我们通过FlagHere表来查看列输入2;show columns from FlagHere;# 来查看列 、 重新构造payload:0;HAND…...

Blackcat V2.2付费会员制WordPress资源站主题

Blackcat-付费会员制WordPress资源站主题,该主题是基于简约实用的主题选项框架 Codestar Framework 进行开发的功能强大的付费会员制主题,该主题尤其适合用于搭建付费下载资源网站,比如素材站、软件站、视频教程站等付费资源下载网站。 集成…...

动手学强化学习 第 18 章 离线强化学习 训练代码

基于 https://github.com/boyu-ai/Hands-on-RL/blob/main/%E7%AC%AC18%E7%AB%A0-%E7%A6%BB%E7%BA%BF%E5%BC%BA%E5%8C%96%E5%AD%A6%E4%B9%A0.ipynb 理论 离线强化学习 修改了警告和报错 运行环境 Debian GNU/Linux 12 Python 3.9.19 torch 2.0.1 gym 0.26.2 运行代码 CQL.…...

Python笔试面试题AI答之面向对象常考知识点

Python面向对象面试题面试题覆盖了Python面向对象编程(OOP)的多个重要概念和技巧,包括元类(Metaclass)、自省(Introspection)、面向切面编程(AOP)和装饰器、重载&#xf…...

面试经典算法150题系列-数组/字符串操作之买卖股票最佳时机

买卖股票最佳时机 给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。 你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最大利润。 返回你可以从这笔交易…...

安装jdk和tomcat

安装nodejs 1.安装nodejs,这是一个jdk一样的软件运行环境 yum -y list installed|grep epel yum -y install nodejs node -v 2.下载对应的nodejs软件npm yum -y install npm npm -v npm set config .....淘宝镜像 3.安装vue/cli command line interface 命令行接…...

mongodb 备份还原

### 加入 MongoDB 官方 repositoryecho [mongodb-org-4.4] nameMongoDB Repository baseurlhttps://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/4.4/x86_64/ gpgcheck1 enabled1 gpgkeyhttps://www.mongodb.org/static/pgp/server-4.4.asc| tee /etc/yum.repos.d/mo…...

day27——homework

1、使用两个线程完成两个文件的拷贝&#xff0c;分支线程1拷贝前一半&#xff0c;分支线程2拷贝后一半&#xff0c;主线程回收两个分支线程的资源 #include <stdio.h> #include <stdlib.h> #include <pthread.h> #include <fcntl.h> #include <uni…...

shell脚本自动化部署

1、自动化部署DNS [rootweb ~]# vim dns.sh [roottomcat ~]# yum -y install bind-utils [roottomcat ~]# echo "nameserver 192.168.8.132" > /etc/resolv.conf [roottomcat ~]# nslookup www.a.com 2、自动化部署rsync [rootweb ~]# vim rsync.sh [rootweb ~]# …...

C语言| 文件操作详解(二)

目录 四、有关文件的随机读写函数 4.1 fseek 4.2 ftell 4.3 rewind 五、判定文件读取结束的标准与读写文件中途发生错误的解决办法 5.1 判定文件读取结束的标准 5.2 函数ferror与feof 5.2.1 函数ferror 5.2.2 函数feof 在上一章中&#xff0c;我们主要介绍了文件类型…...

保证项目如期上线,测试人能做些什么?

要保证项目按照正常进度发布&#xff0c;需要整个研发团队齐心协力。 有很多原因都可能会造成项目延期。 1、产品经理频繁修改需求 2、开发团队存在技术难题 3、测试团队测不完 今天我想跟大家聊一下&#xff0c;测试团队如何保证项目按期上线&#xff0c;以及在这个过程中可能…...

攻防对抗:利用IP段归属查询工具快速封禁攻击源——3步联动防火墙(附脚本)

深夜两点&#xff0c;服务器告警声响起。SSH日志中&#xff0c;来自同一运营商IP段的暴力破解尝试正在快速轮换——这不是单点攻击&#xff0c;而是有组织的分布式扫描。面对这类场景&#xff0c;传统按单个IP逐一封禁的方式已力不从心。一、2025年攻击态势&#xff1a;DDoS攻击…...

嵌入式系统事件控制与连续处理架构设计

1. 嵌入式系统的事件控制连续处理架构解析 在工业自动化领域&#xff0c;嵌入式系统需要同时应对两种截然不同的处理需求&#xff1a;一方面要持续不断地处理传感器采集的实时数据流&#xff0c;另一方面又必须及时响应各种异步事件&#xff08;如用户指令、设备状态变化等&…...

Qwen3-32B智能问答系统搭建:基于API的快速开发指南

Qwen3-32B智能问答系统搭建&#xff1a;基于API的快速开发指南 1. 环境准备与快速部署 在开始使用Qwen3-32B构建智能问答系统前&#xff0c;我们需要完成基础环境准备。Qwen3-32B作为320亿参数的大型语言模型&#xff0c;其API调用方式既简单又高效。 1.1 获取API访问凭证 …...

PLM系统在环保合规设计中的关键作用与实施路径

1. 环保合规设计的行业挑战与PLM解决方案价值在电子产品和汽车制造业&#xff0c;材料合规管理已成为产品设计的核心环节。过去五年间&#xff0c;全球新增了47项与有害物质管控相关的法规&#xff0c;其中中国RoHS 2.0和欧盟REACH法规的更新频率达到每年2-3次。某国际汽车零部…...

Python类型守卫深度解析

一、引言&#xff1a;类型收窄与类型守卫的价值 在静态类型检查的Python开发中&#xff0c;类型收窄(Type Narrowing) 是核心技术之一&#xff0c;它让类型检查器能够在代码执行路径中推断出变量更精确的类型&#xff0c;从而减少类型错误并提升代码的可读性与可维护性。例如&a…...

从SiamFC到SiamMask:用PySOT工具包复现孪生网络跟踪算法全流程(附避坑指南)

从SiamFC到SiamMask&#xff1a;PySOT工具包实战指南与深度解析 在计算机视觉领域&#xff0c;目标跟踪一直是一个极具挑战性的研究方向。随着深度学习技术的快速发展&#xff0c;基于孪生网络的跟踪算法因其出色的性能和实时性而备受关注。本文将带您深入探索从SiamFC到SiamMa…...

龙迅 LT8775 Type‑C/DP1.4/eDP1.4 转双 MIPI DSI+LVDS 桥接芯片详解

最近做车载中控、便携 4K 屏、VR 双显方案&#xff0c;用到龙迅 LT8775&#xff0c;整理完整参数、应用与调试要点&#xff0c;分享给大家。 一、芯片定位与核心规格 LT8775 是龙迅高性能 Type‑C/DP1.4/eDP1.4 转双 MIPI DSI LVDS 视频桥接芯片&#xff0c;内置 MCUEDID/HDCP…...

F2803x DSP ePWM模块实战:从基础配置到高精度电机控制

1. ePWM模块基础配置与电机控制入门 第一次接触F2803x的ePWM模块时&#xff0c;我完全被那些专业术语搞懵了。什么时基模块、比较模块、动作模块&#xff0c;听起来就像天书。但当我真正动手配置一个简单的电机驱动电路后&#xff0c;才发现这套系统设计得非常巧妙。下面我就用…...

golang如何实现日志按级别过滤_golang日志按级别过滤实现教程

slog 默认不支持级别过滤&#xff0c;需自定义 Handler 实现&#xff1a;通过 LevelFilterHandler 包装标准 Handler&#xff0c;在 Handle 方法中判断 rec.Level > minLevel 决定是否输出。log/slog 默认不支持级别过滤&#xff0c;得自己加 HandlerGo 1.21 的 slog 包本身…...

AI辅助排版:设计领域的应用方法与落地实践

数字化内容生产节奏不断加快&#xff0c;品牌方对内容输出的频率和质量要求同步提升。不少中小设计团队因为排版效率不足&#xff0c;无法承接高频次的内容输出需求。特别是电商大促节点&#xff0c;不少中小团队一周要承接近百套商品详情页、平台活动海报、新媒体种草内容的排…...