Java线程6种状态:
1.new(初始化):start()方法转runnable
2.runnable(可执行/执行): 等待synchronized 的隐式锁时转blocked
3.blocked(阻塞): 当等待的线程获得 synchronized 隐式锁时,就又会从 BLOCKED 转换到 RUNNABLE 状态
4.waiting(无限期等待): 三种情况:
- 第一种场景,获得 synchronized 隐式锁的线程,调用无参数的 Object.wait() 方法
- 第二种场景,调用无参数的 Thread.join() 方法.当A执行完,调用的线程又会回到running状态.
- 第三种场景,调用 LockSupport.park() 方法。其中的 LockSupport 对象,也许你有点陌生,其实 Java 并发包中的锁,都是基于它实现的。调用 LockSupport.park() 方法,当前线程会阻塞,线程的状态会从 RUNNABLE 转换到 WAITING。调用 LockSupport.unpark(Thread thread) 可唤醒目标线程,目标线程的状态又会从 WAITING 状态转换到 RUNNABLE。
5.time-waiting(有限期等待):调用带时间参数的方法.sleep(long millis),wait(long timeout),join(long millis),parkUntil(long deadline),parkNanos(Object blocker, long deadline)
有五种场景会触发这种转换:
- 调用带超时参数的 Thread.sleep(long millis) 方法;
- 获得 synchronized 隐式锁的线程,调用带超时参数的 Object.wait(long timeout) 方法;
- 调用带超时参数的 Thread.join(long millis) 方法;
- 调用带超时参数的 LockSupport.parkNanos(Object blocker, long deadline) 方法;
- 调用带超时参数的 LockSupport.parkUntil(long deadline) 方法。
这里你会发现 TIMED_WAITING 和 WAITING 状态的区别,仅仅是触发条件多了超时参数。
6:TERMINATED(终止):1.执行完.2.被interrupt()