你使用过哪些 Java 并发工具类?
你的回答(口语化,面试场景)
面试官:你使用过哪些 Java 并发工具类?
你:
好的,我结合项目经验来说说常用的并发工具类:
- CountDownLatch
- 作用:等所有线程就绪后再触发任务,或主线程等待子线程完成。
- 场景:压测时模拟高并发(比如100个请求同时发起)。
- 代码示例:
CountDownLatch latch = new CountDownLatch(3); // 三个子线程执行任务 executor.submit(() -> { doWork(); latch.countDown(); }); latch.await(); // 主线程阻塞等待 System.out.println("所有任务完成");
- CyclicBarrier
- 作用:让一组线程互相等待,达到屏障点后统一执行后续逻辑。
- 场景:多线程分阶段处理数据(比如先各自加载数据,再统一合并)。
- 代码示例:
CyclicBarrier barrier = new CyclicBarrier(3, () -> System.out.println("全部就绪!")); executor.submit(() -> { loadData(); barrier.await(); // 等待其他线程 mergeData(); });
- Semaphore
- 作用:控制并发线程数(比如限流)。
- 场景:数据库连接池限制、接口限流(防止瞬时流量打满系统)。
- 代码示例:
Semaphore semaphore = new Semaphore(5); // 允许5个线程同时执行 if (semaphore.tryAcquire(2, TimeUnit.SECONDS)) { // 超时等待 try { accessDB(); } finally { semaphore.release(); } }
- ReentrantLock 和 StampedLock
- ReentrantLock:
- 可替代
synchronized,支持公平锁、可中断锁。 - 场景:需要尝试获取锁(
tryLock())或避免死锁(比如支付超时回滚)。
- 可替代
- StampedLock:
- 读多写少场景优化,通过“乐观读”减少锁竞争。
- 场景:高频读、低频写的缓存(比如商品库存缓存)。
- 原子类(AtomicInteger 等)
- 作用:无锁线程安全操作(基于 CAS)。
- 场景:计数器(比如统计接口调用次数)、状态标志。
AtomicInteger counter = new AtomicInteger(0); counter.incrementAndGet(); // 线程安全自增
- Future 和 CompletableFuture
- Future:异步获取任务结果(需配合线程池)。
- CompletableFuture:
- 支持链式调用、组合多个异步任务(如
thenApply()、allOf())。 - 场景:微服务并行调用(比如同时查询订单和用户信息)。
- 支持链式调用、组合多个异步任务(如
- 线程池工具类(Executors)
- 常用线程池:
newFixedThreadPool:固定线程数,适用于稳定负载。newCachedThreadPool:弹性线程数,适合短时异步任务。newScheduledThreadPool:定时任务调度(替代 Timer)。
- 注意:阿里规约建议手动创建
ThreadPoolExecutor,避免资源耗尽风险。
- 并发集合(ConcurrentHashMap、CopyOnWriteArrayList)
- ConcurrentHashMap:
- 分段锁(JDK7)或 CAS + synchronized(JDK8),高并发下替代 HashMap。
- 场景:全局缓存(比如电商首页类目数据)。
- CopyOnWriteArrayList:
- 写时复制,读多写少场景(比如监听器列表)。
预测面试官可能的追问及回答
追问1:CountDownLatch 和 CyclicBarrier 有什么区别?
回答:
- 触发机制:
CountDownLatch通过countDown()减计数,await()阻塞直到计数归零,一次性使用。CyclicBarrier通过await()等待线程数达标后触发回调,可重复使用(reset())。
- 场景:
CountDownLatch主等子,CyclicBarrier子等子。
追问2:ReentrantLock 和 synchronized 怎么选?
回答:
- 优先
synchronized:代码简洁,JVM自动管理锁。 - 需要高级功能时用
ReentrantLock:比如尝试获取锁(tryLock)、公平锁、可中断锁。
知识框架与底层原理补充
-
并发工具分类
| 类别 | 工具类 | 解决的核心问题 |
|--------------------|------------------------------------------|-------------------------------|
| 线程协作 |CountDownLatch,CyclicBarrier| 多线程步调协调 |
| 资源控制 |Semaphore, 线程池 | 限制并发资源使用 |
| 锁机制 |ReentrantLock,StampedLock| 显式控制同步与互斥 |
| 线程安全容器 |ConcurrentHashMap,CopyOnWriteArrayList| 高并发下数据安全访问 |
| 异步任务 |Future,CompletableFuture| 非阻塞任务编排与结果获取 | -
底层原理
- AQS(AbstractQueuedSynchronizer):
ReentrantLock、Semaphore、CountDownLatch均基于 AQS 实现,通过state变量和 CLH 队列管理线程阻塞与唤醒。
- CAS(Compare-And-Swap):
- 原子类(如
AtomicInteger)和ConcurrentHashMap的线程安全操作依赖 CAS,避免锁竞争。
- 原子类(如
- 写时复制(Copy-On-Write):
CopyOnWriteArrayList在写入时复制整个数组,保证读操作无锁,适合读多写极少场景。
- 最佳实践
- 避免死锁:
- 锁顺序一致、超时释放(
tryLock)、使用并发集合替代手动同步。
- 锁顺序一致、超时释放(
- 性能优化:
- 读多写少用
StampedLock,写多用ReentrantLock。 - 短任务用
CompletableFuture而非阻塞线程池。
- 读多写少用
- 线程池参数:
- 根据任务类型(CPU 密集型 vs IO 密集型)设置核心线程数(CPU 数 +1 或 2*CPU 数)。
- 高频面试题扩展
ConcurrentHashMap在 JDK7 和 JDK8 的区别?- JDK7:分段锁(Segment),锁粒度粗。
- JDK8:CAS + synchronized 锁单个 Node,粒度更细。
CompletableFuture的默认线程池问题?- 默认使用
ForkJoinPool.commonPool(),建议自定义线程池避免业务阻塞公共池。
- 默认使用
通过理解这些工具类的设计意图和底层机制,你可以在面试中展现出对高并发场景的深刻掌控力!
相关文章:
你使用过哪些 Java 并发工具类?
你的回答(口语化,面试场景) 面试官:你使用过哪些 Java 并发工具类? 你: 好的,我结合项目经验来说说常用的并发工具类: CountDownLatch 作用:等所有线程就绪后再触发任务…...
模板方法模式的C++实现示例
核心思想 模板方法设计模式是一种行为设计模式,它定义了一个算法的框架,并将某些步骤的具体实现延迟到子类中。通过这种方式,模板方法模式允许子类在不改变算法结构的情况下重新定义算法的某些步骤。 模板方法模式的核心在于: …...
国产编辑器EverEdit - 脚本(解锁文本编辑的无限可能)
1 脚本 1.1 应用场景 脚本是一种功能扩展代码,用于提供一些编辑器通用功能提供不了的功能,帮助用户在特定工作场景下提高工作效率,几乎所有主流的编辑器、IDE都支持脚本。 EverEdit的脚本支持js(语法与javascript类似)、VBScript两种编程…...
越早越好!8 个反直觉的金钱真相|金钱心理学
很多人都追求财富自由,但成功的人少之又少。 这可能是因为,人们往往忽略了一些金钱的真相和常识。 01 金钱常识 & 真相 为了构建健康的金钱观,我读了一本有点反直觉,有点像鸡汤,但都是财富真相的书。 来自 Morg…...
linux docker相关指令
1、镜像操作 0)、搜索:docker search 镜像名称 1)、拉取:docker pull 2)、推送:docker push 3)、查看:docker images 4)、查看所有镜像ID:d…...
实时采集到的语音进行语音识别
要在.NET Framework 4.8中使用C#实现离线实时语音识别,可以使用开源库Vosk(支持离线ASR)配合音频处理库NAudio。 步骤 1:安装依赖库 1.1. 安装NuGet包: - Install-Package NAudio(处理音频输入)…...
Ollama 本地部署 DeepSeek R1 及 Python 运行 open-webui 界面(windows)
DeepSeek R1 ollama open-webui 本地部署(windows) DeepSeek-R1本地部署配置要求 Github地址:https://github.com/deepseek-ai/DeepSeek-R1?tabreadme-ov-file 模型规模最低 GPU 显存推荐 GPU 型号纯 CPU 内存需求适用场景1.5B4GBRTX 3…...
牛客周赛:84:C:JAVA
链接:登录—专业IT笔试面试备考平台_牛客网 来源:牛客网 题目描述 \hspace{15pt}本题为《D.小红的陡峭值(三)》的简单版本,两题的唯一区别在于本题的数据范围更小。 \hspace{15pt}小红定义一个字符串的陡峭值为&a…...
5. 前后端实现文件上传与解析
1. 说明 在实际开发中,比较常见的一个功能是需要在前端页面中选择系统中的某个文件上传到服务器中进行解析,解析后的文件内容可以用来在服务器中当作参数,或者传递给其它组件使用,或者需要存储到数据库中。所以本文就提供一种方式…...
SpringBoot 接入 豆包 火山方舟大模型
火山方舟控制台 开通模型推理、知识库 应用入口; 文档中心 各类接口说明及SDK 获取; 向量数据库VikingDB 文档 下翻找到有java操作案例; 实现目标功能效果: 通过SDK调用 豆包大模型,在代码内实现问答的效果…...
IDEA接入阿里云百炼中免费的通义千问[2025版]
安装deepseek 上一篇文章IDEA安装deepseek最新教程2025中说明了怎么用idea安装codeGPT插件,并接入DeepSeek,无奈接入的官方api已经不能使用了,所以我们尝试从其他地方接入 阿里云百炼https://bailian.console.aliyun.com/ 阿里云百炼是阿…...
下载kali linux遇到的一些问题
kali官网:kali官网跳转 问题一:未启动VM Service VMware Workstation 未能启动 VMware Authorization Service。您可以尝试手动启动VMware Authorization Service。如果此问题仍然存在,请联系VMware 支持部门。 解决办法: 步骤1…...
常见排序算法深度评测:从原理到10万级数据实战
常见排序算法深度评测:从原理到10万级数据实战 摘要 本文系统解析冒泡排序、选择排序、插入排序、希尔排序、归并排序、快速排序、堆排序和基数排序8种经典算法,通过C语言实现10万随机数排序并统计耗时。测试显示:快速排序综合性能最优&…...
Scaled_dot_product_attention(SDPA)使用详解
在学习huggingFace的Transformer库时,我们不可避免会遇到scaled_dot_product_attention(SDPA)这个函数,它被用来加速大模型的Attention计算,本文就详细介绍一下它的使用方法,核心内容主要参考了torch.nn.functional中该函数的注释…...
Linux练级宝典->Linux进程概念介绍
目录 进程基本概念 PCB概念 task_struct tack_struct内容分类 PID和PPID fork函数创建子进程 进程优先级概念 4个名词 进程地址空间 进程地址空间的意义 内核进程调度队列 优先级 活动队列 过期队列 进程基本概念 一个正在执行的程序。担当分配系统资源的实体&#…...
OpenHarmony 5.0 mpegts封装的H265视频播放失败的解决方案
问题现象 OpenHarmony 5.0版本使用AVPlayer播放mpegts封装格式的H.265(HEVC)编码格式的视频时出现报错导致播放失败 问题原因 OpenHarmony 5.0版本AVPlayer播放器使用histreamer引擎,因为 libav_codec_hevc_parser.z.so 动态库未开源导致H265编码格式视频解析不到…...
Qt从入门到入土(九) -model/view(模型/视图)框架
简介 Qt的模型/视图(Model/View)架构是一种用于分离数据处理和用户界面展示的设计模式。它允许开发者将数据存储和管理(模型)与数据的显示和交互(视图)解耦,从而提高代码的可维护性和可扩展性。…...
缓存之美:Guava Cache 相比于 Caffeine 差在哪里?
大家好,我是 方圆。本文将结合 Guava Cache 的源码来分析它的实现原理,并阐述它相比于 Caffeine Cache 在性能上的劣势。为了让大家对 Guava Cache 理解起来更容易,我们还是在开篇介绍它的原理: Guava Cache 通过分段(…...
[漏洞篇]XSS漏洞详解
[漏洞篇]XSS漏洞 一、 介绍 概念 XSS:通过JS达到攻击效果 XSS全称跨站脚本(Cross Site Scripting),为避免与层叠样式表(Cascading Style Sheets, CSS)的缩写混淆,故缩写为XSS。这是一种将任意 Javascript 代码插入到其他Web用户页面里执行以…...
【Leetcode 每日一题】2269. 找到一个数字的 K 美丽值
问题背景 一个整数 n u m num num 的 k k k 美丽值定义为 n u m num num 中符合以下条件的 子字符串 数目: 子字符串长度为 k k k。子字符串能整除 n u m num num。 给你整数 n u m num num 和 k k k,请你返回 n u m num num 的 k k k 美丽值…...
(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)
题目:3442. 奇偶频次间的最大差值 I 思路 :哈希,时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况,哈希表这里用数组即可实现。 C版本: class Solution { public:int maxDifference(string s) {int a[26]…...
DeepSeek 赋能智慧能源:微电网优化调度的智能革新路径
目录 一、智慧能源微电网优化调度概述1.1 智慧能源微电网概念1.2 优化调度的重要性1.3 目前面临的挑战 二、DeepSeek 技术探秘2.1 DeepSeek 技术原理2.2 DeepSeek 独特优势2.3 DeepSeek 在 AI 领域地位 三、DeepSeek 在微电网优化调度中的应用剖析3.1 数据处理与分析3.2 预测与…...
mongodb源码分析session执行handleRequest命令find过程
mongo/transport/service_state_machine.cpp已经分析startSession创建ASIOSession过程,并且验证connection是否超过限制ASIOSession和connection是循环接受客户端命令,把数据流转换成Message,状态转变流程是:State::Created 》 St…...
连锁超市冷库节能解决方案:如何实现超市降本增效
在连锁超市冷库运营中,高能耗、设备损耗快、人工管理低效等问题长期困扰企业。御控冷库节能解决方案通过智能控制化霜、按需化霜、实时监控、故障诊断、自动预警、远程控制开关六大核心技术,实现年省电费15%-60%,且不改动原有装备、安装快捷、…...
ElasticSearch搜索引擎之倒排索引及其底层算法
文章目录 一、搜索引擎1、什么是搜索引擎?2、搜索引擎的分类3、常用的搜索引擎4、搜索引擎的特点二、倒排索引1、简介2、为什么倒排索引不用B+树1.创建时间长,文件大。2.其次,树深,IO次数可怕。3.索引可能会失效。4.精准度差。三. 倒排索引四、算法1、Term Index的算法2、 …...
k8s业务程序联调工具-KtConnect
概述 原理 工具作用是建立了一个从本地到集群的单向VPN,根据VPN原理,打通两个内网必然需要借助一个公共中继节点,ktconnect工具巧妙的利用k8s原生的portforward能力,简化了建立连接的过程,apiserver间接起到了中继节…...
【HTTP三个基础问题】
面试官您好!HTTP是超文本传输协议,是互联网上客户端和服务器之间传输超文本数据(比如文字、图片、音频、视频等)的核心协议,当前互联网应用最广泛的版本是HTTP1.1,它基于经典的C/S模型,也就是客…...
Element Plus 表单(el-form)中关于正整数输入的校验规则
目录 1 单个正整数输入1.1 模板1.2 校验规则 2 两个正整数输入(联动)2.1 模板2.2 校验规则2.3 CSS 1 单个正整数输入 1.1 模板 <el-formref"formRef":model"formData":rules"formRules"label-width"150px"…...
蓝桥杯3498 01串的熵
问题描述 对于一个长度为 23333333的 01 串, 如果其信息熵为 11625907.5798, 且 0 出现次数比 1 少, 那么这个 01 串中 0 出现了多少次? #include<iostream> #include<cmath> using namespace std;int n 23333333;int main() {//枚举 0 出现的次数//因…...
GC1808高性能24位立体声音频ADC芯片解析
1. 芯片概述 GC1808是一款24位立体声音频模数转换器(ADC),支持8kHz~96kHz采样率,集成Δ-Σ调制器、数字抗混叠滤波器和高通滤波器,适用于高保真音频采集场景。 2. 核心特性 高精度:24位分辨率,…...
