多线程状态改变图解

下面这是一张线程状态切换示意图
在这里插入图片描述
在这里插入图片描述

1)新创建一个新的线程对象后,再调用它的start()方法,系统会为此线程分配CPU资
源,使其处于Runnable(可运行)状态,这是一个准备运行的阶段。如果线程抢占到CPU资
源,此线程就处于Running(运行)状态。
2) Runnable状态和Running 状态可相互切换,因为有可能线程运行一段时间后,有其
他高优先级的线程抢占了CPU资源,这时此线程就从Running状态变成Runnable状态。
线程进人Runnable状态大体分为如下5种情况:

  1. 调用sleep()方法后经过得时间超过了指定的休眠时间
  2. 线程调用的阻塞IO已经返回,阻塞方法执行完毕。
  3. 口线程成功地获得了试图同步的监视器。
  4. 线程正在等待某个通知,其他线程发出了通知。
  5. 处于挂起状态的线程调用了resume恢复方法。

3 )Blocked是阻塞的意思,例如遇到了一个IO操作,此时CPU处于空闲状态,可能会
转而把CPU时间片分配给其他线程,这时也可以称为“暂停”状态。Blocked状态结束后,
进入Runnable状态,等待系统重新分配资源。
出现阻塞的情况大体分为如下5种:

  1. 线程调用sleep方法,主动放弃占用的处理器资源。
  2. 线程调用了阻塞式IO方法,在该方法返回前,该线程被阻塞。
  3. 线程试图获得一个同步监视器,但该同步监视器正被其他线程所持有。
  4. 线程等待某个通知。
  5. 程序调用了suspend方法将该线程挂起。此方法容易导致死锁,尽量避免使用该方法。

4 ) run(方法运行结束后进入销毁阶段,整个线程执行完毕。
总结:
每个锁对象都有两个队列,一个是就绪队列,一个是阻塞队列.就绪队列存储了将要获
得锁的线程,阻塞队列存储了被阻塞的线程。一个线程被唤醒后,才会进入就绪队列,等待
得锁的线程,阻塞队列存储了被阻塞的线程.一个线程被唤醒后,才会进入就绪队列,等待
CPU的调度;反之,一个线程被wait后,就会进入阻塞队列,等待下一次被唤醒。
Cpu的调度;反之,一个线程被等待后,就会进入阻塞队列,等待下一次被唤醒。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值