Java多线程详解(三)线程状态
(1)线程状态的简要说明
(2)线程状态转换过程中常用的方法
(3)停止线程
(4)线程休眠
(5)线程礼让(yield)
(6)线程强制执行(join)
(7)线程状态的观测
线程的几个状态:
- NEW:尚未启动的线程处于此状态
- RUNNABLE:再Java虚拟机中执行的线程处于此状态
- BLOCKED:被阻塞等待监视器锁定的线程处于此状态
- WAITING:正在等待另一个线程执行动作达到指定等待时间的线程处于此状态
- TIMED_WAITING:正在等待另一个线程执行动作达到指定等待时间的线程处于此状态
- TERMINATED:已退出的线程处于此状态,可以理解为此线程已死亡,已退出的线程不能再被重新启动,会报错
public class TestState {
public static void main(String[] args) throws InterruptedException {
Thread thread = new Thread(()->{
for (int i = 0; i < 5; i++) {
try {
Thread.sleep(500);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
System.out.println("//");
});
//观察状态
Thread.State state = thread.getState();//NEW
System.out.println(state);
//观察启动后
thread.start();//启动线程
state = thread.getState();//RUNNABLE
System.out.println(state);
while (state != Thread.State.TERMINATED){//只要线程不中止,就一直输出状态
Thread.sleep(1000);
state = thread.getState();
System.out.println(state);
}
}
}
结果如下:
可以发现,再线程被创建的时候,线程的状态为NEW,线程启动后状态转为RUNNABLE,随后线程sleep,状态随即转为TIMED_WAITING,最终线程执行完毕后,状态转为TERMINATED。
(8)线程的优先级
- Java提供一个线程调度器来监控程序中启动后进入就绪状态的所有线程,线程调度器按照优先级决定应该调度那个线程来执行
- 线程的优先级用数字表示,范围从1-10
- Thread.MIN_PRIORITY = 1;
- Thread.MAX_PRIORITY = 10;
- Thread.NORM_PRIORITY = 5; 线程默认的优先级
- 使用以下方式改变或获取优先级
- getPriority() setPriority()
public class TestPriority {
public static void main(String[] args) {
//主线程默认优先级
System.out.println(Thread.currentThread().getName()+"--->"+Thread.currentThread().getPriority());
MyPriority myPriority = new MyPriority();
Thread t1 = new Thread(myPriority);
Thread t2 = new Thread(myPriority);
Thread t3 = new Thread(myPriority);
Thread t4 = new Thread(myPriority);
Thread t5 = new Thread(myPriority);
//先设置优先级,再启动
t1.start();
t2.setPriority(1);
t2.start();
t3.setPriority(2);
t3.start();
t4.setPriority(4);
t4.start();
t5.setPriority(Thread.MAX_PRIORITY);
t5.start();
}
}
class MyPriority implements Runnable{
@Override
public void run() {
System.out.println(Thread.currentThread().getName()+"--->"+Thread.currentThread().getPriority());
}
}
最终结果如下:
可以发现并不是优先级设置的越高就先执行,可以理解为高的优先级只是增加了被系统调度的概率。