线程池 waiting on condition_死磕 java线程系列之线程的生命周期

本文深入探讨Java线程的生命周期,纠正了网上关于线程状态的常见误解。详细分析了synchronized锁和基于AQS的锁中线程状态的变化,包括线程在同步队列、等待队列中的流转状态,并提供了测试用例进行验证。
摘要由CSDN通过智能技术生成
c5ad01e54f510e2d55e06cb09a254dc1.png

(手机横屏看源码更方便)

注:java源码分析部分如无特殊说明均基于 java8 版本。

简介

大家都知道线程是有生命周期,但是彤哥可以认真负责地告诉你网上几乎没有一篇文章讲得是完全正确的。

常见的错误有:就绪状态、运行中状态(RUNNING)、死亡状态、中断状态、只有阻塞没有等待状态、流程图乱画等,最常见的错误就是说线程只有5种状态。

今天这篇文章会彻底讲清楚线程的生命周期,并分析synchronized锁、基于AQS的锁中线程状态变化的逻辑。

所以,对synchronized锁和AQS原理(源码)不了解的同学,请翻一下彤哥之前的文章先熟悉这两部分的内容,否则肯定记不住这里讲的线程生命周期。

问题

(1)线程的状态有哪些?

(2)synchronized锁各阶段线程处于什么状态?

(3)重入锁、条件锁各阶段线程处于什么状态?

先上源码

关于线程的生命周期,我们可以看一下java.lang.Thread.State这个类,它是线程的内部枚举类,定义了线程的各种状态,并且注释也很清晰。

public enum State { /** * 新建状态,线程还未开始 */ NEW, /** * 可运行状态,正在运行或者在等待系统资源,比如CPU */ RUNNABLE, /** * 阻塞状态,在等待一个监视器锁(也就是我们常说的synchronized) * 或者在调用了Object.wait()方法且被notify()之后也会进入BLOCKED状态 */ BLOCKED, /** * 等待状态,在调用了以下方法后进入此状态 * 1. Object.wait()无超时的方法后且未被notify()前,如果被notify()了会进入BLOCKED状态 * 2. Thread.join()无超时的方法后 * 3. LockSupport.park()无超时的方法后 */ WAITING, /** * 超时等待状态,在调用了以下方法后会进入超时等待状态 * 1. Thread.sleep()方法后【本文由公从号“彤哥读源码”原创】 * 2. Object.wait(tim
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值