线程状态
新建状态
new Thread() 后 该线程处于新建状态,与其他Java对象一样,未表现出线程的特征;
就绪状态
当 Thread的对象 调用了 start方法后,该线程处于 就绪状态;
JVM会为当前线程创建 运行时环境(虚拟机栈、程序计数器);
处于 就绪状态的线程 并未开始执行,需要等待CPU的调度;
运行状态
处于就绪状态的线程 获得CPU后,开始执行run方法,此时该线程处于 运行状态;
阻塞状态
如下情况,处于运行状态的线程将进入阻塞状态:
线程 主动调用 sleep方法,放弃CPU资源;
线程 调用了阻塞IO的方法,在方法返回之前,将被阻塞;
线程 试图获取同步监视器,但 该同步监视器被其他线程持有;
线程 等待某个通知(notify);
线程 主动调用suspend,将线程挂起(容易导致死锁);
如下情况,处于阻塞状态的线程重新进入就绪状态:
sleep方法超过了时间;
调用的阻塞IO方法返回;
成功取得同步监视器;
等待某个通知,其他线程发出了通知;
处于挂起状态的线程 被 调用了resume;
死亡状态
如下情况,进入死亡状态:
run方法执行结束;
线程抛出一个Exception或Error;
直接调用stop方法(容易死锁);
判断某个线程是否死亡,使用isAlive;
处于 就绪&运行&阻塞 状态时,返回true;
处于 新建&死亡 状态时,返回false;
线程控制
join
让一个线程 等待 另一个线程完成;
在当前线程中 调用 其他线程的join,当前线程将一直被阻塞,直到被加入的线程执行完成;
sleep
在当前线程中 调用 sleep,当前线程将被一直阻塞,直到过了sleep时间;
yield
Thread的static方法,让当前正在执行的线程 暂停 但 不会阻塞(进入就绪状态);
当调用了Thread的yield方法后,只有 与当前线程同等优先级 或 大于当前线程优先级的线程 才有抢占CPU资源的机会;
线程的协调运行
Object的Wait()&Notify()&NotifyAll()
这3个方法 必须由 同步监视器 调用;
wait():
导致 当前线程等待,直到 其他线程调用该同步监视器的notify()/notifyAll() ;
notify():
唤醒 在此同步监视器上 等待的单个线程(如果有多个,随机唤醒一个);
notifyAll():
唤醒 在此同步监视器上 等待的所有线程;
标签:状态,调用,控制,阻塞,线程,监视器,就绪 From: https://www.cnblogs.com/anpeiyong/p/17989877