多线程状态改变图解

    科技2026-03-06  6

    下面这是一张线程状态切换示意图

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

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

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

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

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

    Processed: 0.009, SQL: 9