
java并发学习21:线程状态转换
发布日期:2021-05-07 02:04:32
浏览次数:19
分类:精选文章
本文共 2694 字,大约阅读时间需要 8 分钟。
1、情况 1 NEW --> RUNNABLE
- 当调用t.start()方法时,由NEW --> RUNNABLE
2、情况 2 RUNNABLE <–> WAITING
t 线程用synchronized(obj)获取了对象锁后
-
调用obj.wait()方法时,t 线程从RUNNABLE --> WAITING
-
调用obj.notify(),obj.notifyAll(),t.interrupt()时
- 竞争锁成功,t 线程从WAITING --> RUNNABLE
- 竞争锁失败,t 线程从WAITING --> BLOCKED
public class Test WaitNotify { final static Object obj = new Object(); public static void main(String[] args) { newThread(() -> { synchronized (obj) { log.debug("执行...."); try { obj.wait(); } catch (InterruptedExceptione) { e.printStackTrace(); } log.debug("其它代码...."); // 断点 } },"t1").start(); newThread(() -> { synchronized (obj) { log.debug("执行...."); try { obj.wait(); } catch (InterruptedExceptione) { e.printStackTrace(); } log.debug("其它代码...."); // 断点 } },"t2").start(); sleep(0.5); log.debug("唤醒 obj 上其它线程"); synchronized (obj) { obj.notifyAll(); // 唤醒obj上所有等待线程断点 } }}
3、情况 3 RUNNABLE <–> WAITING
-
当前线程调用t.join()方法时,当前线程从RUNNABLE --> WAITING
- 注意是当前线程在t 线程对象的监视器上等待
-
t 线程运行结束,或调用了当前线程的interrupt()时,当前线程从WAITING --> RUNNABLE
4、情况 4 RUNNABLE <–> WAITING
- 当前线程调用LockSupport.park()方法会让当前线程从RUNNABLE --> WAITING
- 调用LockSupport.unpark(目标线程)或调用了线程的interrupt(),会让目标线程从WAITING --> RUNNABLE
5、情况 5 RUNNABLE <–> TIMED_WAITING
t 线程用synchronized(obj)获取了对象锁后
- 调用obj.wait(long n)方法时,t 线程从RUNNABLE --> TIMED_WAITING
- t 线程等待时间超过了 n 毫秒,或调用obj.notify(),obj.notifyAll(),t.interrupt()时
- 竞争锁成功,t 线程从TIMED_WAITING --> RUNNABLE
- 竞争锁失败,t 线程从TIMED_WAITING --> BLOCKED
6、情况 6 RUNNABLE <–> TIMED_WAITING
- 当前线程调用t.join(long n)方法时,当前线程从RUNNABLE --> TIMED_WAITING
- 注意是当前线程在t 线程对象的监视器上等待
- 当前线程等待时间超过了 n 毫秒,或t 线程运行结束,或调用了当前线程的interrupt()时,当前线程从TIMED_WAITING --> RUNNABLE
7、情况 7 RUNNABLE <–> TIMED_WAITING
- 当前线程调用Thread.sleep(long n),当前线程从RUNNABLE --> TIMED_WAITING
- 当前线程等待时间超过了 n 毫秒,当前线程从TIMED_WAITING --> RUNNABLE
8、情况 8 RUNNABLE <–> TIMED_WAITING
- 当前线程调用LockSupport.parkNanos(long nanos)或LockSupport.parkUntil(long millis)时,当前线程从RUNNABLE --> TIMED_WAITING
- 调用LockSupport.unpark(目标线程)或调用了线程的interrupt(),或是等待超时,会让目标线程从TIMED_WAITING–> RUNNABLE
9、情况 9 RUNNABLE <–> BLOCKED
- t 线程用synchronized(obj)获取了对象锁时如果竞争失败,从RUNNABLE --> BLOCKED
- 持 obj 锁线程的同步代码块执行完毕,会唤醒该对象上所有BLOCKED的线程重新竞争,如果其中t 线程竞争成功,从BLOCKED --> RUNNABLE,其它失败的线程仍然BLOCKED
10、情况 10 RUNNABLE <–> TERMINATED
- 当前线程所有代码运行完毕,进入TERMINATED
发表评论
最新留言
第一次来,支持一个
[***.219.124.196]2025年04月13日 19时56分46秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
快速学习汇编之 常见汇编指令
2021-05-08
变量覆盖漏洞
2021-05-08
java 之 集合篇
2021-05-08
weblogic之cve-2015-4852
2021-05-08
Java注释
2021-05-08
水调歌头·1024
2021-05-08
对不起
2021-05-08
C++ 函数默认参数
2021-05-08
C++ 函数重载
2021-05-08
C++ sort()函数使用简介
2021-05-08
Kickdown UVA - 1588
2021-05-08
matlab文件管理
2021-05-08
Printer Queue UVA - 12100
2021-05-08
【并发编程】实现多线程的几种方式
2021-05-08
设计模式系列博客传送门
2021-05-08
设计模式——访问者模式
2021-05-08
同步锁 —— ReentrantReadWriteLock
2021-05-08
Nginx简介
2021-05-08
Nginx的Gzip功能
2021-05-08
当我们开发一个接口时需要注意些什么
2021-05-08