当前位置:网站首页>线程三连鞭之“线程的状态”
线程三连鞭之“线程的状态”
2022-08-04 23:21:00 【小洪正在努力】
一:线程有哪些状态?
- 新生:NEW
- 运行:RUNNABLE
- 阻塞:BLOCKED
- 等待:WAITING
- 超时等待:TIMED_WAITING
- 终止:TERMINATED
二:线程的基本概念,图形理解以及状态间的关系

- 新建(new):新建线程对象。
- 可运行(runnanble):线程对象创建后,其他线程(比如main线程)调用了该对象的start( )方。该状态的线程位于可运行线程池中,等待被线程调度选中,获得CPU的使用权。
- 运行(running):可运行状态(runnable)的线程获得CPU时间片,执行程序代码。
- 阻塞(blocked):阻塞状态是线程因为某种原因放弃了CPU的使用权,暂时停止运行,知道线程进入可运行状态(runnable)才有机会再次获得CPU分配的时间片进入运行状态(running)。
- 死亡(dead):线程run( ), main( )方法执行结束,或者因为异常推出了run( )方法,则该线程结束生命周期。
阻塞的情况分三种:
① 同步阻塞:获得同步锁时,该锁被别的线程占用,JVM会把该线程放进锁池中。
②其他阻塞:调用了sleep( )或者join( )方法。JVM 会把该线程置为阻塞状态。当 sleep ()状态超时、 join ()等待线程终止或者超时、或者 I /O 处理完毕时,线程重新转入可运行( runnable )状态。
③等待阻塞:执行wait( )方法,JVM会把该线程放入等待队列进入Waiting状态,等待其他线程notify通知唤醒。
边栏推荐
- C5750X7R2E105K230KA(电容器)MSP430F5249IRGCR微控制器资料
- MySQL的安装与卸载
- 特征工程资料汇总
- Nuclei (2) Advanced - In-depth understanding of workflows, Matchers and Extractors
- The role of @Async annotation and how to implement asynchronous listening mechanism
- 【字符串函数内功修炼】strcpy + strcat + strcmp(一)
- Will we still need browsers in the future?(feat. Maple words Maple language)
- PID控制器改进笔记之七:改进PID控制器之防超调设定
- [QNX Hypervisor 2.2用户手册]10.5 vdev ioapic
- 一点点读懂thermal(一)
猜你喜欢
随机推荐
[Cultivation of internal skills of string functions] strlen + strstr + strtok + strerror (3)
一点点读懂regulator(三)
当panic或者die被执行时,或者发生未定义指令时,如何被回调到
一点点读懂cpufreq(二)
npm基本操作及命令详解
Vscode连接远程服务器(一套配置成功)
3年,从3K涨薪到20k?真是麻雀啄了牛屁股 — 雀食牛逼呀
App测试和Web测试的区别
Community Sharing|Tencent Overseas Games builds game security operation capabilities based on JumpServer
MYS-6ULX-IOT 开发板测评——使用 Yocto 添加软件包
@Import注解的作用以及如何使用
panic: reflect: reflect.Value.SetString using value obtained using unexported field
OPENCV学习DAY8
小黑leetcode冲浪:94. 二叉树的中序遍历
Flutter启动流程(Skia引擎)介绍与使用
ClickHouse 二级索引
【七夕快乐篇】Nacos是如何实现服务注册功能的?
PAN3020 Sub-1G无线收发芯片
Pytorch分布式训练/多卡/多GPU训练DDP的torch.distributed.launch和torchrun
Implementing class target method exception using proxy object execution









