高级java每日一道面试题-2024年12月28日-并发篇-了解Semaphore吗?

news2025/1/1 10:51:20

如果有遗漏,评论区告诉我进行补充

面试官: 了解Semaphore吗?

我回答:

在Java高级面试中,Semaphore(信号量)是一个重要的并发控制工具,它用于控制同时访问特定资源的线程数量,以确保资源的合理使用。以下是对Semaphore的详细解析:

一、Semaphore的基本概念

Semaphore(信号量)是一种基于计数的同步机制,它允许多个线程同时访问某个资源池,但会限制可以同时访问该资源的线程数量。Semaphore通过维护一个内部计数器来跟踪当前可用的许可数量,当线程需要访问资源时,它会尝试从Semaphore获取一个许可,如果许可可用,则线程可以继续执行;如果许可不可用,则线程将被阻塞,直到有许可被释放为止。

二、Semaphore的使用场景

Semaphore通常用于那些资源有明确访问数量限制的场景,例如:

  1. 数据库连接池:同时连接数据库的线程数量有限,当连接数达到限制时,后续的线程需要等待前面的线程释放数据库连接。
  2. 停车场管理:停车场的车位数量有限,当车位满时,新的车辆需要等待有空位才能进入。
  3. 文件读写:同时允许并发访问某个文件的线程数量有限,以避免文件损坏或数据不一致。
  4. 线程池:限制同时运行的任务数量。
  5. 资源访问控制:如上面的例子所示,限制对特定资源的并发访问。
  6. 流量控制:在网络编程中,可以用来限制同一时间处理的数据包数量。

三、Semaphore的主要方法

Semaphore提供了几个关键的方法来管理许可:

  1. acquire():获取一个许可,如果没有可用的许可,则当前线程将被阻塞,直到有许可被释放。
  2. tryAcquire():尝试获取一个许可,如果没有可用的许可,则立即返回false,而不会阻塞当前线程。
  3. release():释放一个许可,增加可用许可的数量,并可能唤醒一个正在等待许可的线程。
  4. availablePermits():返回当前可用的许可数量。
  5. drainPermits():清空所有可用的许可,返回清空前可用的许可数量。
  6. reducePermits(int reduction):减少可用许可的数量。
  7. increasePermits(int increase):增加可用许可的数量。

四、Semaphore的实现原理

Semaphore基于AbstractQueuedSynchronizer(AQS)的共享模式实现。在Semaphore初始化时,会创建一个同步阻塞队列,并将初始的许可数量赋值给队列的state状态。当线程调用acquire方法时,它会尝试从队列中获取一个许可:

  • 如果state的值大于0,表示有可用的许可,线程将获取一个许可,并将state的值减1。
  • 如果state的值为0,表示没有可用的许可,线程将被阻塞,并加入到一个等待队列中。当有其他线程释放许可时,等待队列中的线程将被唤醒,并尝试重新获取许可。

五、Semaphore的示例代码

以下是一个使用Semaphore的示例代码,用于模拟一个停车场的管理系统:

import java.util.concurrent.Semaphore;
import java.util.Random;

public class TestCar {
    // 停车场同时容纳的车辆数量
    private static Semaphore semaphore = new Semaphore(10);

    public static void main(String[] args) {
        // 模拟100辆车进入停车场
        for (int i = 0; i < 100; i++) {
            Thread thread = new Thread(new Runnable() {
                public void run() {
                    try {
                        System.out.println("====" + Thread.currentThread().getName() + "来到停车场");
                        if (semaphore.availablePermits() == 0) {
                            System.out.println("车位不足,请耐心等待");
                        }
                        semaphore.acquire(); // 获取令牌尝试进入停车场
                        System.out.println(Thread.currentThread().getName() + "成功进入停车场");
                        Thread.sleep(new Random().nextInt(10000)); // 模拟车辆在停车场停留的时间
                        System.out.println(Thread.currentThread().getName() + "驶出停车场");
                        semaphore.release(); // 释放令牌,腾出停车场车位
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
            }, i + "号车");
            thread.start();
        }
    }
}

在这个示例中,我们创建了一个初始可用资源为10的Semaphore对象,然后模拟了100辆车进入停车场的过程。每辆车都会尝试获取一个许可(即一个车位),如果车位不足,则车辆会被阻塞在停车场入口。当有车辆离开停车场时,会释放一个许可,从而允许新的车辆进入。

六、Semaphore的公平与非公平模式

Semaphore有两种模式:公平模式和非公平模式。

  • 公平模式:按照线程调用acquire方法的顺序来获取许可,即先来的线程先获得许可。
  • 非公平模式:允许抢占式的获取许可,即后来的线程也有可能先获得许可。

在默认情况下,Semaphore使用的是非公平模式。如果需要公平模式,可以在创建Semaphore对象时传入一个true参数。

总结

Semaphore 是一种强大的同步工具,适用于需要限制并发访问数量的场景。通过合理配置其参数和使用方法,可以有效地管理和优化系统的并发性能。

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

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

相关文章

vue之axios基本使用

文章目录 1. axios 网络请求库2. axiosvue 1. axios 网络请求库 <body> <input type"button" value"get请求" class"get"> <input type"button" value"post请求" class"post"> <!-- 官网提供…

javaEE-多线程案例-单例模式

目录 啥是设计模式? 一.饿汉式 实现步骤&#xff1a; 二.懒汉式 实现步骤: 三、懒汉式优化1 四.懒汉式优化2 五.懒汉式优化3 总代码: 单例模式是一种设计模式。 啥是设计模式? 设计模式好⽐象棋中的"棋谱".红⽅当头炮,⿊⽅⻢来跳.针对红⽅的⼀些⾛法,⿊…

TCP Analysis Flags 之 TCP Out-Of-Order

前言 默认情况下&#xff0c;Wireshark 的 TCP 解析器会跟踪每个 TCP 会话的状态&#xff0c;并在检测到问题或潜在问题时提供额外的信息。在第一次打开捕获文件时&#xff0c;会对每个 TCP 数据包进行一次分析&#xff0c;数据包按照它们在数据包列表中出现的顺序进行处理。可…

鸿蒙开发实战之“使用HiLog和HiSysEvent进行日志与系统事件管理”

HiLog和HiSysEvent作为鸿蒙&#xff08;HarmonyOS&#xff09;系统中进行日志记录和系统事件管理的关键组件&#xff0c;为开发者提供了强大的工具来追踪系统行为、调试应用以及监控设备状态。它们不仅简化了日志管理和事件追踪的流程&#xff0c;还提高了开发效率和系统可维护…

机器学习之PCA降维

主成分分析&#xff08;PCA&#xff0c;Principal Component Analysis&#xff09; 主成分分析&#xff08;PCA&#xff09;是一种常见的无监督学习技术&#xff0c;广泛应用于数据降维、数据可视化以及特征提取等任务。PCA的目标是通过线性变换将数据从高维空间映射到低维空间…

【CSS in Depth 2 精译_098】17.3:CSS 动画延迟技术与填充模式设置 + 17.4:通过 CSS 动画传递意图的秘诀

当前内容所在位置&#xff08;可进入专栏查看其他译好的章节内容&#xff09; 第五部分 添加动效 ✔️【第 17 章 动画】 ✔️ 17.1 关键帧17.2 3D 变换下的动画设置 17.2.1 添加动画前页面布局的构建17.2.2 为布局添加动画 17.3 动画延迟与填充模式 ✔️17.4 通过动画传递意图…

python+PyMuPDF库:(一)创建pdf文件及内容读取和写入

目录 文档操作 打开文档 获取文档信息 删除页 复制页 移动页 选择重构合并 保存关闭 页对象操作 内容读取 获取页对象的字体样式 插入文本标签 插入文本内容 字体设置 insert_text添加文本 insert_textbox添加文本 插入图片 获取页面注释、链接、表单字段 …

Datawhale AI冬令营 动手学AI Agent

背景——什么是Agent 在人工智能领域&#xff0c;agent可以指一个能够感知环境并作出决策以实现特定目标的系统。比如&#xff0c;一个聊天机器人&#xff08;chatbot&#xff09;就是一个agent&#xff0c;它能够理解用户的输入并给出相应的回复。 学习目标 学会使用百宝箱…

高精度保形滤波器Savitzky-Golay的数学原理、Python实现与工程应用

面向信号处理的特征保持平滑技术 在数据分析领域&#xff0c;信号处理中的噪声问题始终是一个重要议题。无论是实验数据、金融时间序列还是其他形式的信号处理&#xff0c;噪声都会干扰目标模式和趋势的识别。尽管存在多种降噪方法&#xff0c;但在处理短时信号时&#xff0c;…

九点标定+旋转标定

眼在手外方式 1.夹取make点位置要求 机械手夹具夹持一个款标定板或者物料露出make点让视觉定位抓取 高度&#xff1a;与产品识别高度一致 左右位置&#xff1a;在相机视野内可以拍到make点 2.机械手走9个点移动位置要求&#xff08;九点标定&#xff09; 保证make在视野内…

RealityCapture导入视频序列失败

问题原因&#xff1a;如果导入的视频文件存在多余的元数据&#xff0c;那么在这里会发生导入失败。 以本人华为手机拍摄的一段.mp4视频为例&#xff1a; 利用ffmpeg在窗口命令行中检查你的视频—— ffmpeg -i your_video_name.mp4your_video_name是你的视频文件名 如下图所示&…

计算机网络|数据流向剖析与分层模型详解

文章目录 一、网络中的数据流向二、计算机网络通信模型1.OSI 模型2.TCP/IP 模型3.TCP/IP五层模型3.1 分层架构描述3.2各层地址结构3.3UDP数据包报头结构 三、总结 一、网络中的数据流向 在计算机网络中&#xff0c;数据的流向是指数据从发送端到接收端的传输路径。数据流向涉及…

正则表达式(三剑客之awk)

1.awk工具的使用 1.1 截取文档中的某个段 1&#xff09;打印以 : 为分隔的第一个字段 [rootlocalhost ~]# head -n3 /etc/passwd | awk -F : {print $1} 2&#xff09;注意事项 -F&#xff1a;作用是指定分隔符。如果不加分隔符&#xff0c;则以空格或者tab为分隔符 print&…

【基于rust-wasm的前端页面转pdf组件和示例】

基于rust-wasm前端页面转pdf组件和示例 朔源多余的废话花哨的吹牛那点东西要不要拿来试试事到如今 做个美梦 我觉得本文的意义在于,wasm扩展了浏览器的边界,但是又担心如同java的web applet水土不服. 如同我至今看不出塞班和iOS的不同下载地址&#xff1a;在github的备份 朔源…

图扑可视化赋能挖掘机高效操控

数字孪生挖掘机通过图扑可视化实时数据呈现和精准环境模拟&#xff0c;提升操作精度与施工效率&#xff0c;助力施工项目可视化管理&#xff0c;优化资源配置&#xff0c;为工程机械行业带来了新的智能化革新。

【多维DP】力扣3366. 最小数组和

给你一个整数数组 nums 和三个整数 k、op1 和 op2。 你可以对 nums 执行以下操作&#xff1a; 操作 1&#xff1a;选择一个下标 i&#xff0c;将 nums[i] 除以 2&#xff0c;并 向上取整 到最接近的整数。你最多可以执行此操作 op1 次&#xff0c;并且每个下标最多只能执行一…

支付域——“奖、惩、贴“特殊清算

摘要 在现代的服务平台经济中&#xff0c;比如网约车、外卖服务等&#xff0c;奖惩机制是用来管理服务提供者行为和确保服务品质的一种重要工具。所谓的“奖惩贴”就是这种机制中的一种具体形式&#xff0c;它包括了给予服务提供者的奖金、罚款和补贴。这些措施能够激励平台商…

网易企业邮箱登陆:保障数据安全

网易企业邮箱是一款为企业提供安全可靠的电子邮件服务的工具。通过网易企业邮箱&#xff0c;企业可以实现员工之间的高效沟通和信息共享&#xff0c;同时保障数据的安全性。 企业邮箱的安全性是企业信息保护的重要组成部分。网易企业邮箱采用了多层加密技术&#xff0c;确保邮件…

java常用类(下)

笔上得来终觉浅,绝知此事要躬行 &#x1f525; 个人主页&#xff1a;星云爱编程 &#x1f525; 所属专栏&#xff1a;javase &#x1f337;追光的人&#xff0c;终会万丈光芒 &#x1f389;欢迎大家点赞&#x1f44d;评论&#x1f4dd;收藏⭐文章 目录 一、Math 类 1.1基本介…

计算机的错误计算(一百九十四)

摘要 用两个大模型计算 其中&#xff0c;一个大模型通过化简&#xff0c;得出正确结果 0&#xff1b;而另外一个在化简过程中出现错误&#xff0c;得出了错误结果。 例1. 计算 下面是一个大模型的推导化简过程。 以上为一个大模型的回答。 下面是另外一个大模型的回复。 点评…