面经自测——死锁/死锁的必要条件/死锁的预防/进程通信的方式

前言

在这里插入图片描述

本文是作者专门用来自测Java后端相关面试题的,所有问题都是在牛客、知识星球或网上找到的最近最新的面试题,全文回答都是作者按自己的真实水平仿照真实环境的回答,所以答案不一定真实(但回答一定真诚🤣),其他即将面试的小伙伴可以试试自测一下💪

谈谈死锁,它产生的必要条件,以及如何预防的?

好的,

首先对于死锁,它其实是在多任务环境中,也就是在两个或多个进程的执行过程中,因为争夺资源产生的一种僵局状态,因为已经资源被分配完,所以所有的进程都在等待对方释放资源,但谁都不释放,导致所有的进程都无法继续执行

然后,死锁的发送必须满足四个条件,这四个条件缺一不可,这四个条件分别是:互斥条件、占有和等待条件、不可抢占条件和循环等待条件

一定要解释一下四个条件的定义,这是问题的核心!!!

  • 互斥条件:资源不能被多个进程同时使用,一个资源一次只能由一个进程占用
  • 占有和等待条件:进程至少占有一个资源,并且等待获取其他进程占有的资源
  • 不可抢占条件:资源只能由占有它的进程资源释放,不能被强制夺走
  • 循环等待条件:存在一个进程资源的循环等待链,每个进程都在等待下一个进程所占有的资源

由刚刚的死锁产生的四个必要条件,我们可以知道预防死锁的策略,因为四个条件缺一不可,所以我们只要破坏其中一个条件死锁也就不会发送了

  • 破坏互斥条件:这在实际操作中很难实现,因为很多资源天生就是需要互斥访问的。
  • 破坏占有和等待条件:可以通过要求进程在开始执行前一次性请求所有需要的资源来实现,但这可能导致资源利用率低下。
  • 破坏不可抢占条件:允许资源被抢占,但这在实际操作中可能很复杂,并且可能导致数据不一致。
  • 破坏循环等待条件:通过对所有资源类型进行排序,并要求进程按顺序请求资源,可以避免循环等待。

关于死锁知识点,还有死锁的避免,检测和解除

你知道进程通信的方式嘛?

当然,进程通信是操作系统中的一个非常重要的概念,它允许不同的进程之间交换信息,协同工作。在多任务操作系统中,进程通信时实现资源共享和任务协调的关键机制

简单解释了什么是进程通信后,就开始说进程通信的方式了,因为进程通信的方式有很多,能说几个说几个

  • 管道(Pipes)和命名管道(Named Pipes)
    管道是一种最基本的进程通信方式,它允许具有亲缘关系的进程(比如父子进程)进行通信。管道是单向的,数据只能从一端流向另一端。而命名管道则允许不具有亲缘关系的进程进行通信,它类似于文件,可以通过路径名进行访问。

  • 消息队列(Message Queues)
    消息队列提供了一种从一个进程向另一个进程发送数据的方式,这些数据被存储在队列中,直到接收进程读取它们。消息队列支持异步通信,并且可以跨多个进程和系统进行通信。

  • 信号量(Semaphores)和互斥锁(Mutexes)
    信号量和互斥锁主要用于控制对共享资源的访问。信号量可以用于控制多个进程对共享资源的访问数量,而互斥锁则确保一次只有一个进程可以访问共享资源,从而避免竞态条件。

  • 共享内存(Shared Memory)
    共享内存是一种效率非常高的进程通信方式,它允许两个或多个进程共享一个给定的存储区。由于多个进程可以同时操作同一块内存,因此共享内存是最快的进程通信方式,但也需要额外的同步措施来避免数据不一致。

  • 套接字(Sockets)
    套接字是一种更为通用的进程通信机制,它不仅支持本机进程间的通信,还支持跨网络的进程通信。套接字可以基于TCP/IP协议提供可靠的通信服务,也可以基于UDP提供不可靠的快速通信。

  • 信号(Signals)
    信号是一种比较复杂的进程通信方式,它用于通知进程某个事件已经发生。信号可以用于处理异步事件,比如中断和终端输入。

结尾话语
每种进程通信方式都有其特定的用途和限制。在实际应用中,选择合适的进程通信方式还是要取决于具体的应用需求,比如通信的进程是否具有亲缘关系、是否需要同步、是否跨网络通信等。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

计算机网络研究实训室建设方案

一、概述 本方案旨在规划并实施一个先进的计算机网络研究实训室,旨在为学生提供一个深入学习、实践和研究网络技术的平台。实训室将集教学、实验、研究于一体,覆盖网络基础、网络架构、网络安全、网络管理等多个领域,以培养具备扎实理论基础…

React开发 - 技术细节汇总一

React简介 React 是一个声明式,高效且灵活的用于构建用户界面的 JavaScript 库。使用 React 可以将一些简短、独立的代码片段组合成复杂的 UI 界面,这些代码片段被称作“组件”。 ui render (data) -> 单向数据流 MVC // model var myapp {}; // …

嵌入式蓝桥杯学习4 lcd移植

cubemx配置 复制前面配置过的文件 打开cubemx,将PB8,PB9配置为GPIO-Output。 点击GENERATE CODE. 文件移植 1.打开比赛提供的文件包,点击Inc文件夹 2.点击Inc文件夹。复制fonts.h和lcd.h,粘贴到我们自己的工程文件夹的bsp中&#xff08…

迭代器模式的理解和实践

引言 在软件开发中,我们经常需要遍历容器对象(如数组、列表、集合等)中的元素。如果每个容器对象都实现自己的遍历算法,那么代码将会变得冗余且难以维护。为了解决这个问题,迭代器模式应运而生。迭代器模式是一种行为型…

STM32一keil5更换芯片后报错问题的解决。

目录 一、STM32型号认识二、报错问题三、常用的启动配置文件四、问题解决 一、STM32型号认识 二、报错问题 当我们在原来工程下修改芯片时,原本可以编译通过的代码突然很多报错。如下所示,这是因为我们的启动文件配置错误。对于不同型号的芯片其flash容量…

人工智能-自动驾驶领域

目录 引言自动驾驶与人工智能的结合为什么自动驾驶领域适合发表文章博雅智信的自动驾驶辅导服务结语 引言 自动驾驶技术的崛起是当代交通行业的一场革命。通过结合先进的人工智能算法、传感器技术与计算机视觉,自动驾驶不仅推动了技术的进步,也使得未来…

c++数据结构算法复习基础--11--高级排序算法-快速排序-归并排序-堆排序

高阶排序 1、快速排序 冒泡排序的升级算法 每次选择一个基准数,把小于基准数的放到基准数的左边,把大于基准数的放到基准数的右边,采用 “ 分治算法 ”处理剩余元素,直到整个序列变为有序序列。 最好和平均的复杂度&#xff1a…

修改MySQL存储路径

1.查看原路径 show variables like ‘%datadir%’; 2.停止MYSQL 以管理员身份运行命令提示符 net stop MySQL84 在服务中直接停止MySQL 3.编辑配置文件 可能会遇到无权限修改,可以先修改my.ini的权限。可以通过:右键my.ini → 属性 → 安全→ 编辑 …

微信小程序报错:http://159.75.169.224:7300不在以下 request 合法域名列表中,请参考文档

要解决此问题,需打开微信小程序开发者工具进行设置,打开详情-本地设置重新运行,该报错就没有啦

深入浅出:使用 Gin 框架生成 API 文档

深入浅出:使用 Gin 框架生成 API 文档 在现代 Web 开发中,API 文档是开发者之间沟通的重要桥梁。它不仅帮助前端开发者理解如何调用后端接口,还为测试人员和运维人员提供了宝贵的参考。对于 Go 语言开发者来说,Gin 是一个非常流行…

【 工具变量】IPCC碳排放因子数据测算表

一、数据简介: 排放因子法是IPCC提出的一种碳排放估算方法,也是目前适用范围最广、应用最为普遍的方法。将各类能源消耗的实物统计量转变为标准统计量,再乘以各自的碳排放因子,加总之后就可以得到碳排放总量。如果按照ISO14064标…

兔子的寿命有多长?

在宠物的世界里,兔子以其灵动的身姿、柔软的皮毛和温顺的性格深受人们喜爱。然而,当我们满心欢喜地将兔子迎进家门时,可曾想过它们能陪伴我们多久?兔子的寿命,是一个值得深入探讨的话题,它不仅关乎生命的时…

echarts地图立体效果,echarts地图点击事件,echarts地图自定义自定义tooltip

一.地图立体效果 方法1:两层地图叠加 实现原理:geo数组中放入两个地图对象,通过修改zlevel属性以及top,left,right,bottom形成视觉差 配置项参考如下代码: geo: [{zlevel: 2,top: 96,map: map,itemStyle: {color: #091A51ee,opacity: 1,borderWidth: 2,borderColor: #16BAFA…

游戏发布AppStore平台

首先,要注册一个开发者账号。这里不多说了,下载官方app“Developer”,然后买个能发布的账号,个人💲99的就行。(其实还有点麻烦,我的好像是人脸识别后出问题了,反正遇到问题找苹果官方…

​​​​​​​移远通信基于高通平台发布可集成边缘计算功能的5G MBB解决方案

在5G技术与人工智能深度融合的背景下,各行各业正迎来前所未有的创新机遇。为了加速5G移动宽带(MBB)行业向智能化转型,并简化边缘计算应用的开发流程,移远通信近期隆重推出了基于骁龙5G调制解调器及射频系统打造&#x…

flinkSql 将流和表的互相转换

流——>表 方式一 方式二 方式一&#xff1a;写sql DataStreamSource<String> source env.socketTextStream("localhost", 8881); // 表名&#xff0c;流&#xff0c;字段名称 tableEnv.createTemporaryView("t_1",source&#xff0c;$("…

React性能优化

三个可以优化的地方 避免过度多次渲染 组件会在以下情况下重新渲染 注意&#xff1a;例如组件组合的形式&#xff0c;<Test><Counter></Counter></Test>,即使Test发生了重新渲染&#xff0c;Counter也不会重新渲染。另外使用React这样的库或框架时&a…

分布式事务的前世今生-纯理论

一个可用的复杂的系统总是从可用的简单系统进化而来。反过来这句话也正确: 从零开始设计的复杂的系统从来都用不了&#xff0c;也没办法让它变的可用。 --John Gal 《系统学》 1975 1. 事务的概念 百科&#xff1a; 事务&#xff08;Transaction&#xff09;&#xff0c;一般是…

k8s-编写CSI插件(3)

1、概述 在 Kubernetes 中&#xff0c;存储插件的开发主要有以下几种方式&#xff1a; CSI插件&#xff1a;Container Storage Interface (CSI) 是 Kubernetes 的标准插件接口&#xff0c;是全新的插件方案&#xff0c;插件和驱动调用通过grpc协议&#xff0c;功能丰富&#x…

Linux系统:网络

目录 一、网络协议 1.网络协议概念 2.协议分层 3.OSI七层模型和TCP/IP五层&#xff08;或四层&#xff09;模型 4.为什么要有网络协议&#xff1f; 5.网络通信协议的原理 二、网络传输的基本流程 1.局域网的网络传输流程 1.MAC地址 2.局域网通信原理&#xff08;以太网…