⭐ 作者:小胡_不糊涂
作者主页:小胡_不糊涂的个人主页
收录专栏:JavaEE
持续更文,关注博主少走弯路,谢谢大家支持
线程的状态是一个枚举类型 Thread.State
执行这段代码可以观察到线程的几种状态:
public static void main(String[] args) {
for (Thread.State state : Thread.State.values()) {
System.out.println(state);
}
}
线程状态 | 说明 |
---|---|
NEW | 初始状态,线程被构建,但是还没有调用start()方法 |
RUNNABLE | 运行状态,Java线程将操作系统中的就绪和运行两种状态笼统地称作“运行中”,分为READY(就绪)、RUNNING(运行) |
BLOCKED | 阻塞状态,表示线程阻塞于锁 |
WAITING | 等待状态,表示线程进入等待状态,进入该状态表示当前线程需要等待其他线程做出一些特定动作(通知或中断) |
TIME_WAITING | 超时等待状态,该状态不同于WAITING,它是可以在指定的时间自行返回的 |
TERMINATED | 终止状态,表示当前线程已经执行完毕 |
public class TestDemo1 {
public static void main(String[] args) {
Thread thread=new Thread(()->{
for(int i=0;i<10;i++){
}
},"我是一个小线程");
System.out.println(thread.getName()+":"+thread.getState());
thread.start();
//isAlive() ⽅法,可以认为只要不是 NEW 和 TERMINATED 的状态都是活着的。
while(thread.isAlive()) {
System.out.println(thread.getName() + ":" + thread.getState());
}
System.out.println(thread.getName()+":"+thread.getState());
}
}
public class TestDemo1 {
public static void main(String[] args) {
Object loker=new Object();
Thread t1=new Thread(()->{
synchronized (loker){
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
throw new RuntimeException(e);
}
System.out.println(Thread.currentThread().getName());
}
},"t1");
t1.start();
Thread t2=new Thread(new Runnable() {
@Override
public void run() {
System.out.println("我是t2线程");
}
});
t2.start();
}
}
通过观察jconsole.exe可知,t1是处于TIMED_WAITING状态,t2处于BLOKERED状态。
当我们修改 Thread.sleep(1000);
为 loker.wait(1000);
,此时t1的状态就变为 WAITING,
直到notify将它唤醒。
结论: