Thread类中用state枚举定义了线程的6种状态:
各状态具体含义:
NEW(新建):创建后尚未启动的线程处于这个状态。
RUNNABLE(可运行):Java线程中将就绪(ready)和运行中(running)两种状态笼统的称为“运行”,也就是处于此状态的线程可能正在运行,也可能正在等待系统资源,如等待CPU为它分配时间片,等待网络IO读取数据。两种状态之间的相互转换是系统调度完成的,可以调用yeild()方法将线程从运行中切换到就绪状态。
BLOCKED(阻塞):BLOCKED称为阻塞状态,当尝试进入一个synchronized语句块/方法时,锁已经被其它线程占有,就会被阻塞,直到获取到锁。
WAITING(无限期等待):该状态的线程不会被分配CPU执行时间,它们要等待显示的被其它线程唤醒。这种状态通常是指一个线程拥有对象锁后进入到相应的代码区域后,调用相应的“锁对象”的wait()方法操作后产生的一种结果。实现的方法有:
Object.wait()
Thread.join():底层还是调用的wait方法。
LockSupport.park()
5、TIMED_WAITING(限期等待)
以下方法会让线程进入TIMED_WAITING限期等待状态:处于这种状态的线程也不会被分配CPU执行时间,不过无需等待被其它线程显示的唤醒,在一定时间之后它们会由系统自动的唤醒。
Thread.sleep()方法
设置了timeout参数的Object.wait()
设置了timeout参数的Thread.join()
LockSupport.parkNanos()方法
LockSupport.parkUntil()方法
6、TERMINATED(结束)
已终止线程的线程状态,线程已经结束执行。正常运行结束或者抛出异常。
线程状态转换如下:(来源于:Java线程状态和生命周期)
使用Jstack查看线程状态
代码如下:
public class ThreadStatusTest {
public static void main(String[] args) throws InterruptedException {
Thread t = new Thread(new IORun(),"IO");
t.start();
}
}
class IORun implements Runnable{
private InputStream in = System.in;
@Override
public void run() {
try {
System.out.println("请输入数据");
//在等待输入时查看线程状态
int read = in.read();
System.out.println("输入数据为:"+read);
} catch (IOException e) {
e.printStackTrace();
}
}
}
1.打开命令行窗口,输入Jps命令获取当前进程ip。当前进程ThreadStatusTest的ip为12248
C:\Users\53556>jps
12248 ThreadStatusTest
7464 Launcher
10300
12716 Jps
2.使用jstack命令查询当前进程所有线程状态。可以知道在等待IO输入时,线程为Runnable状态。
参考资料:
https://blog.csdn.net/pange1991/article/details/53860651
https://www.cnblogs.com/trust-freedom/p/6606594.html
https://blog.csdn.net/qq_29631069/article/details/70833584
以上参考资料的线程状态图在wait方法被唤醒时,都有问题,且不一致。最后使用的是以下资料的图
https://www.cnblogs.com/trust-freedom/p/6606594.html