你使用过哪些 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 美丽值…...
Vim 调用外部命令学习笔记
Vim 外部命令集成完全指南 文章目录 Vim 外部命令集成完全指南核心概念理解命令语法解析语法对比 常用外部命令详解文本排序与去重文本筛选与搜索高级 grep 搜索技巧文本替换与编辑字符处理高级文本处理编程语言处理其他实用命令 范围操作示例指定行范围处理复合命令示例 实用技…...
设计模式和设计原则回顾
设计模式和设计原则回顾 23种设计模式是设计原则的完美体现,设计原则设计原则是设计模式的理论基石, 设计模式 在经典的设计模式分类中(如《设计模式:可复用面向对象软件的基础》一书中),总共有23种设计模式,分为三大类: 一、创建型模式(5种) 1. 单例模式(Sing…...
模型参数、模型存储精度、参数与显存
模型参数量衡量单位 M:百万(Million) B:十亿(Billion) 1 B 1000 M 1B 1000M 1B1000M 参数存储精度 模型参数是固定的,但是一个参数所表示多少字节不一定,需要看这个参数以什么…...
多场景 OkHttpClient 管理器 - Android 网络通信解决方案
下面是一个完整的 Android 实现,展示如何创建和管理多个 OkHttpClient 实例,分别用于长连接、普通 HTTP 请求和文件下载场景。 <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas…...
华为OD机试-食堂供餐-二分法
import java.util.Arrays; import java.util.Scanner;public class DemoTest3 {public static void main(String[] args) {Scanner in new Scanner(System.in);// 注意 hasNext 和 hasNextLine 的区别while (in.hasNextLine()) { // 注意 while 处理多个 caseint a in.nextIn…...
C# 类和继承(抽象类)
抽象类 抽象类是指设计为被继承的类。抽象类只能被用作其他类的基类。 不能创建抽象类的实例。抽象类使用abstract修饰符声明。 抽象类可以包含抽象成员或普通的非抽象成员。抽象类的成员可以是抽象成员和普通带 实现的成员的任意组合。抽象类自己可以派生自另一个抽象类。例…...
关于 WASM:1. WASM 基础原理
一、WASM 简介 1.1 WebAssembly 是什么? WebAssembly(WASM) 是一种能在现代浏览器中高效运行的二进制指令格式,它不是传统的编程语言,而是一种 低级字节码格式,可由高级语言(如 C、C、Rust&am…...
DeepSeek 技术赋能无人农场协同作业:用 AI 重构农田管理 “神经网”
目录 一、引言二、DeepSeek 技术大揭秘2.1 核心架构解析2.2 关键技术剖析 三、智能农业无人农场协同作业现状3.1 发展现状概述3.2 协同作业模式介绍 四、DeepSeek 的 “农场奇妙游”4.1 数据处理与分析4.2 作物生长监测与预测4.3 病虫害防治4.4 农机协同作业调度 五、实际案例大…...
react菜单,动态绑定点击事件,菜单分离出去单独的js文件,Ant框架
1、菜单文件treeTop.js // 顶部菜单 import { AppstoreOutlined, SettingOutlined } from ant-design/icons; // 定义菜单项数据 const treeTop [{label: Docker管理,key: 1,icon: <AppstoreOutlined />,url:"/docker/index"},{label: 权限管理,key: 2,icon:…...
关于 ffmpeg设置摄像头报错“Could not set video options” 的解决方法
若该文为原创文章,转载请注明原文出处 本文章博客地址:https://hpzwl.blog.csdn.net/article/details/148515355 长沙红胖子Qt(长沙创微智科)博文大全:开发技术集合(包含Qt实用技术、树莓派、三维、OpenCV…...
