下面以五阶段状态图作解释:
- New——初始状态:线程对象创建成功,但是并没有执行start()方法
- Runnable——就绪态/可运行态:执行了start()方法,创建了新线程
- Running——运行状态:线程得到了CPU的执行权,开始执行
- Dead——消亡状态:程执行完了或者因异常退出了 run() 方法,该线程结束生命周期
- Block——阻塞状态
- Blocked(同步阻塞):
- 执行的时候遇到了锁,而且自己没有得到锁,无法继续往下执行,没办法了只能把自己挂起来,等下次机会;
- Waitting(等待阻塞):
- 执行的时候自己通过 wait() 释放线程、释放锁,陷入了无限的等待,等待notify()、notifyAll()唤醒;
- Timed Waitting(限时阻塞):
- 执行的时候通过Thread.sleep(time)、t.join()、t.join(time)的方式释放线程,但是有时间限制,不像wait()方法,必须有notify()这些方法唤醒;
- 三者区别:
- 同步阻塞:等待获取到锁,然后回到就绪态;
- 等待阻塞:释放cpu,释放锁。一定是有锁的情况下才可执行wait();
- 限时等待阻塞:限时进入阻塞态,释放cpu资源,但如果有锁无法释放锁资源
- Blocked(同步阻塞):
【补:】
1.LockSupport.park()也是中断的一种方式,通过getState()可以发现执行该方法的线程处于WAITTING状态,park()比wait()更强大,除了有锁资源时可以释放锁资源,而且没有锁资源也依然可以执行中断
2.解除中断
2.1.通过别的线程执行unpark,如:LockSupport.unpark(线程对象)
2.2.通过别的线程执行打断标记,如:线程对象.interrupt()