0

0

在Java中什么是活锁和饥饿_Java并发问题类型解析

P粉602998670

P粉602998670

发布时间:2026-01-21 10:05:02

|

617人浏览过

|

来源于php中文网

原创

活锁是线程持续响应冲突、反复退让却无法推进;饥饿是线程可运行但因调度或资源分配不公平而长期得不到执行;死锁是线程互相等待对方释放锁而永久阻塞。

在java中什么是活锁和饥饿_java并发问题类型解析

活锁:线程没卡住,但一直在“礼貌让路”

活锁不是阻塞,而是线程持续响应对方、反复退让却始终无法推进。典型场景是两个线程都试图获取同一组资源(比如 Lock),发现冲突后主动释放已持锁、再重试——结果双方永远在“你让我、我让你”的循环里空转。

  • 常见错误现象:tryLock() 失败后立即 unlock() + sleep(0) 重试,所有线程几乎同步重试,冲突反复发生
  • 真实使用场景:分布式任务队列中失败消息回滚后插回队首,若处理逻辑有缺陷,该消息会被无限重试
  • 关键解决点:引入随机性打破同步节奏。例如重试前调用 Thread.sleep(ThreadLocalRandom.current().nextInt(10, 100))
  • 注意坑:别用固定 sleep(10),否则多线程仍会高度趋同;也别在重试逻辑里漏掉中断检查(Thread.interrupted()),否则无法优雅退出

饥饿:线程能跑,但永远轮不到它

饥饿不是死锁或活锁,是调度或资源分配不公平导致的“长期缺席”。最典型的是低优先级线程被高优先级线程持续压制,或者公平锁未启用时,新线程总比等待久的线程先抢到 ReentrantLock

  • 常见错误现象:用 Thread.setPriority(Thread.MIN_PRIORITY) 后,该线程日志几乎不输出;或 wait() 线程从不被 notify(),而其他线程总被唤醒
  • 真实使用场景:Web 应用中后台统计线程优先级设为 MIN_PRIORITY,而请求处理线程占满 CPU,统计任务永远延迟
  • 关键解决点:禁用线程优先级(JVM 规范不保证跨平台效果);对锁使用 new ReentrantLock(true) 启用公平模式;对共享资源用 java.util.concurrent 包中的公平类(如 LinkedBlockingQueue
  • 注意坑:公平锁会降低吞吐量,别在高频短临界区盲目开启;wait()/notify() 不是公平机制,应改用 Condition 配合公平锁

怎么快速区分这三者?看线程状态和日志

遇到线程“不动了”,先别急着查死锁——用 jstack <pid></pid> 或 JConsole 的“检测死锁”按钮,结果会直接告诉你有没有死锁线程。没有死锁?再观察:

VIVA
VIVA

一个免费的AI创意视觉设计平台

下载
  • 如果线程状态是 RUNNABLE 却无实质进展(比如 CPU 占用高但业务指标不涨),大概率是活锁
  • 如果线程状态是 WAITINGTIMED_WAITING,且长时间停留(比如 parking to wait for ),结合代码看是否在等不公平的锁或 notify,就是饥饿
  • 如果线程状态是 BLOCKED,且堆显示在等另一个线程持有的锁,而对方也在等它——死锁确认

活锁和饥饿都不留明显阻塞痕迹,必须靠日志打点(比如每次重试/每次 wait 前打印时间戳)或监控线程活跃度来定位。

立即学习Java免费学习笔记(深入)”;

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
什么是分布式
什么是分布式

分布式是一种计算和数据处理的方式,将计算任务或数据分散到多个计算机或节点中进行处理。本专题为大家提供分布式相关的文章、下载、课程内容,供大家免费下载体验。

406

2023.08.11

分布式和微服务的区别
分布式和微服务的区别

分布式和微服务的区别在定义和概念、设计思想、粒度和复杂性、服务边界和自治性、技术栈和部署方式等。本专题为大家提供分布式和微服务相关的文章、下载、课程内容,供大家免费下载体验。

251

2023.10.07

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

443

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

605

2023.08.10

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

443

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

605

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

765

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

377

2025.12.24

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.3万人学习

C# 教程
C# 教程

共94课时 | 11.1万人学习

Java 教程
Java 教程

共578课时 | 80.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号