多线程学习笔记:4.线程状态分析

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线程状态和生命周期

124802_AB5e_2885163.png

使用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

 

猜你喜欢

转载自blog.csdn.net/qq_42283110/article/details/86619112