高并发之线程状态

1. 新建状态(New):新创建了一个线程对象。
2. 就绪状态(Runnable):线程对象创建后,其他线程调用了该对象的start()方法。该状态的线程位于可运行线程池中,变得可运行等待获取CPU的使用权
3. 运行状态(Running):就绪状态的线程获取了CPU,执行程序代码。
4. 阻塞状态(Blocked):阻塞状态是线程因为某种原因放弃CPU使用权暂时停止运行直到线程进入就绪状态才有机会转到运行状态。阻塞的情况分三种:
(一)、等待阻塞:运行的线程执行wait()方法,JVM会把该线程放入等待池中。
(二)、同步阻塞:运行的线程在获取对象的同步锁时,若该同步锁被别的线程占用,则JVM会把该线程放入锁池中。
(三)、其他阻塞:运行的线程执行sleep()或join()方法,或者发出了I/O请求时,JVM会把该线程置为阻塞状态。当sleep()状态超时、join()等待线程终止或者超时、或者I/O处理完毕时,线程重新转入就绪状态。
5. 死亡状态(Dead):线程执行完了或者因异常退出了run()方法,该线程结束生命周期。
二. 线程状态图

需要注意点:

  • 当线程调用yield时进入就绪或可运行状态
  • 当线程调用sleep、join、IO阻塞方法时,只有当sleep等待时间结束,join的另一个线程结束任务后返回,io完成才会进入就绪(可运行状态)
  • 当调用被别的线程占的互斥锁时,阻塞直到别的线程释放锁才进入就绪(可运行状态)
  • 当调用wait方法时当前线程挂起,进入阻塞状态,直到notify或notifyAll来唤醒;当nofify唤醒后,继续进行阻塞方法余下的代码...等锁释放后进入就绪或可运行状态
  • wait方法执行后 当前线程会释放锁;这与sleep方法有区别,sleep并不释放锁,一直阻塞知道超时为止

 

posted @   陶朱公Boy  阅读(171)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示