20200630——线程

线程的五种状态

1)新建 new
2)可运行runnable
3)运行 running
4)阻塞 blocked
5)死亡 dead

阻塞的情况分为三种

调用wait()方法,把线程放入等待队列
获取锁的时候,被阻塞了,其他线程拿到锁
io阻塞,sleep和join,jvm把线程设置为阻塞,等其相应的任务完毕,又重新回到runnable状态

线程流程图

在这里插入图片描述


更新一下,了解的不算完整。

线程的状态图(新)

在这里插入图片描述
在这里插入图片描述

new 新建状态,并没有调用start的时候

runnable 可运行状态

就绪状态

已经获取所有资源,CPU分配执行权就可以执行,所有就绪态线程都在就绪队列中。即在就绪状态的进程除CPU之外,其它的运行所需资源都已全部获得

就绪状态只是说你资格运行,调度程序没有挑选到你,你就永远是就绪状态。
调用线程的start()方法,此线程进入就绪状态。
当前线程sleep()方法结束,其他线程join()结束,等待用户输入完毕, 进入就绪状态
当前线程时间片用完了,调用当前线程的yield()方法,当前线程进入就绪状态。
锁池里的线程拿到对象锁后,进入就绪状态。

运行状态

一个cpu只能处理一个线程,当然多核可以多处理

阻塞状态

当然,阻塞的状态如原始我提过的一样,分为三种状态

在这里插入图片描述

等待阻塞:运行的线程执行wait()方法,该线程会释放占用的所有资源,JVM会把该线程放入“等待池”中。进入这个状态后,是不能自动唤醒的,必须依靠其他线程调用notify()或notifyAll()方法才能被唤醒,

同步阻塞 运行的线程在获取对象的同步锁时,若该同步锁被别的线程占用,则JVM会把该线程放入“锁池”中。

其他阻塞运行的线程执行sleep()或join()方法,或者发出了I/O请求时,JVM会把该线程置为阻塞状态。当sleep()状态超时、join()等待线程终止或者超时、或者I/O处理完毕时,线程重新转入就绪状态。

waiting 等待状态

运行的线程执行sleep()或join()方法,或者发出了I/O请求时,JVM会把该线程置为阻塞状态。当sleep()状态超时、join()等待线程终止或者超时、或者I/O处理完毕时,线程重新转入就绪状态。

以下方法会让线程陷入无限期等待状态:

没有设置timeout参数的Object.wait()
没有设置timeout参数的Thread.join()
LockSupport.park()

Timed_Waiting 计时等待

计时等待也是主动放弃CPU执行权的,区别是,超时后会进入阻塞态竞争资源

Thread.sleep()方法
设置了timeout参数的Object.wait()方法
设置了timeout参数的Thread.join()方法
LockSupport.parkNanos()方法
LockSupport.parkUntil()方法

最后还是terminal状态

线程执行结束

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值