操作系统篇--八股文学习第十一天|进程调度算法你了解多少,进程间有哪些通信方式,解释一下进程同步和互斥,以及如何实现进程同步和互斥
进程调度算法你了解多少?
答:
- 先来先服务:按照请求的顺序进行调度。 这种调度方式简单,但是能导致较长作业阻塞较短作业。
- 最短作业优先:非抢占式的调度算法,按估计运行时间最短的顺序进行调度。 但是如果一直有短作业到来,那么长作业永远得不到调度,造成长作业“饥饿”现象。
- 最短剩余时间优先:基于最短作业优先改进,按剩余运行时间的顺序进行调度。当一个新的作业到达时,其整个运行时间与当前进程的剩余时间作比较。如果新的进程需要的时间更少,则挂起当前进程,运行新的进程。否则新的进程等待。
- 优先级调度:为每个进程分配一个优先级,按优先级进行调度。为了防止低优先级的进程永远等不到调度,可以随着时间的推移增加等待进程的优先级。
- 时间片轮转:为每个进程分配一个时间片,进程轮流执行,时间片用完后切换到下一个进程。
多级反馈队列:融合了时间片轮转调度算法和优先级调度算法,通过动态调整进程的优先级和时间片大小,多级反馈队列调度算法可以兼顾多方面的系统目标
多级反馈队列调度算法的实现思想如下:
- 设置多个就绪队列,并为每个队列赋予不同的优先级。第1级队列的优先级最高,第2级队列的优先级次之。其余队列的优先级逐个降低。
- 赋予各个队列的进程运行时间片的大小各不相同。在优先级越高的队列中,每个进程的时间片就越小。例如,第 i+1级队列的时间片要比第i级队列的时间片长1倍。
- 每个队列都采用FCFS算法。当新进程进入内存后,首先将它放入第1级队列的未尾,按FCFS原则等待调度。当轮到该进程执行时,如它能在该时间片内完成,便可撤离系统。若它在一个时间片结束时尚未完成,调度程序将其转入第2级队列的未尾等待调度:若它在第2级队列中运行一个时间片后仍未完成,再将它放入第3级队列.,依此类推。当进程最后被降到第n级队列后,在第n级队列中便采用时间片轮转方式运行。
- 按队列优先级调度。仅当第1级队列为空时,才调度第2级队列中的进程运行;仅当第 1~i-1级队列均为空时,才会调度第i级队列中的进程运行。若处理机正在执行第i级队列中的某进程时,又有新进程进入任一优先级较高的队列,此时须立即把正在运行的进程放回到第级队列的未尾,而把处理机分配给新到的高优先级进程。

进程间有哪些通信方式?
答:
- 管道:是一种半双工的通信方式,数据只能单向流动而且只能在具有父子进程关系的进程间使用。
- 命名管道: 类似管道,也是半双工的通信方式,但是它允许在不相关的进程间通信。
- 消息队列:允许进程发送和接收消息,而消息队列是消息的链表,可以设置消息优先级。
- 信号:用于发送通知到进程,告知其发生了某种事件或条件。
- 信号量:是一个计数器,可以用来控制多个进程对共享资源的访问,常作为一种锁机制,防止某进程正在访问共享资源时,其他进程也访问该资源。因此主要作为进程间以及同一进程内不同线程之间的同步手段。
- 共享内存:就是映射一段能被其他进程所访问的内存,这段共享内存由一个进程创建,但多个进程都可以访问。共享内存是最快的进程通信方式,
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;…...
[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)和装饰器、重载…...
面试经典算法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、使用两个线程完成两个文件的拷贝,分支线程1拷贝前一半,分支线程2拷贝后一半,主线程回收两个分支线程的资源 #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 在上一章中,我们主要介绍了文件类型…...
保证项目如期上线,测试人能做些什么?
要保证项目按照正常进度发布,需要整个研发团队齐心协力。 有很多原因都可能会造成项目延期。 1、产品经理频繁修改需求 2、开发团队存在技术难题 3、测试团队测不完 今天我想跟大家聊一下,测试团队如何保证项目按期上线,以及在这个过程中可能…...
优化SEO效果的长尾关键词运用与关键词调整策略分析
本文将围绕优化SEO效果的长尾关键词运用与关键词调整策略进行深入探讨。首先,长尾关键词在提高网站可见性和搜索引擎排名中扮演着关键角色,能够帮助目标用户找到相关内容。其次,通过分析长尾关键词的特点,可以发现其相较于短尾关键…...
C#类型转换避坑指南:为什么你的Cast方法总抛InvalidCastException?
C#类型转换避坑指南:为什么你的Cast方法总抛InvalidCastException? 在C#开发中,类型转换是每个开发者都会遇到的常见操作。特别是使用LINQ的Cast<T>方法时,稍不注意就会遇到令人头疼的InvalidCastException异常。本文将深入…...
RC522 RFID模块在CW32F030上的SPI驱动移植与MIFARE读写实践
1. RC522射频识别模块技术解析与CW32F030平台移植实践1.1 技术背景与应用定位近场通信(Near Field Communication, NFC)作为短距离高频无线通信技术,其核心源于免接触式射频识别(RFID)技术的演进。RC522模块正是基于IS…...
SpringMVC(1)学习内容
一、SpringMVC 基本概述 1.1 三层架构和MVC 1.1.1 三层架构 三层架构是软件设计中经典的分层架构模式,其核心思想是将应用程序划分为三个职责明确的逻辑层次,实现 "高内聚,低耦合" 的设计目标。 表现层(Presentatio…...
IE11卸载翻车实录:Win10下这些隐藏设置你必须知道(避坑指南)
IE11卸载与系统组件管理的深度解析:Win10用户必知的技术内幕 每次Windows系统更新后,总有些"钉子户"组件让人又爱又恨——IE11就是其中最典型的代表。上周帮同事处理一台无法运行企业内网系统的笔记本时,我再次深刻体会到微软在系统…...
消费战略方法拆解:从判断到落地的完整框架
一、先给定义消费战略如何改变企业:消费战略不是单独增加一个品牌概念,而是帮助企业重新建立“方向—认知—路径”的统一逻辑,让机会需求、核心烙印、产品结构与增长动作进入同一条主线。一句话结论:消费战略真正改变的是企业的判…...
中国香港中文大学深圳分校全球首创视频广告植入新技术
这项由中国香港中文大学深圳分校、深圳环大湾区研究院、纽约州立大学布法罗分校以及哈尔滨工业大学联合完成的研究,于2026年3月发表在计算机视觉领域的顶级学术会议上,论文编号为arXiv:2603.02816v1。研究团队开发了一个名为"BrandFusion"的多…...
Visual Studio 2019下用C语言手把手实现递归下降分析器(附完整代码下载)
从零构建递归下降分析器:Visual Studio 2019实战指南 1. 环境配置与项目初始化 在Windows 10环境下使用Visual Studio 2019开发递归下降分析器,首先需要确保开发环境正确配置。打开Visual Studio 2019,选择"创建新项目",…...
人工智能应用- 预测新冠病毒传染性:01. 新冠疫情与人工智能
2020 年初,新冠疫情席卷全球,深刻改变了我们的生活。在这场与病毒的较量中,人工智能发挥了关键作用——不仅帮助科学家分析疫情趋势、研判防控效果,还能从病毒的基因序列中预测其传染性,为防疫争取宝贵的时间。本节将带…...
基于STM32F407与miniMP3库的流式音频解码与DMA双缓冲播放实践
1. 项目背景与硬件选型 在嵌入式音频播放领域,STM32F407凭借其强大的处理能力和丰富的外设资源成为首选。这款Cortex-M4内核的MCU主频高达168MHz,自带硬件浮点运算单元,特别适合处理音频编解码这类计算密集型任务。我选择MAX98357作为DAC模块…...
