美文网首页
java并发之线程的运行状态

java并发之线程的运行状态

作者: TodoCoder | 来源:发表于2019-02-18 21:22 被阅读0次

    线程用了多年,一直是处于只会用的状态,最近想详细的研究一下多线程,在这里做一下记录。在Thread中一共有6种状态。

    • NEW : 创建了Thread对象,但尚未启动的线程的线程状态.
    • RUNNABLE : 调用start()方法后的可运行状态,这个状态可以切换到除了NEW之外的任何其它状态。
    • BLOCKED :线程阻塞状态。等待监视器的锁,拿到锁后切换回RUNNABLE继续执行。
    • WAITING : 线程等待状态(no timeout). RUNNABLE状态中的线程在掉用Object#wait()、join()或者LockSupport#park()后会进入这个状态。
    • TIMED_WAITING : 线程等待状态(timeout). RUNNABLE状态中的线程在掉用#sleep、Object#wait(long)、join(long)、LockSupport#parkNanos、LockSupport#parkUntil后会进入到这个状态。
    • TERMINATED : 线程运行完毕的线程终止状态。RUNNABLE 执行结束。
      关系图如下图所示
    线程状态

    示例代码如下:

    /**
     * 示例2 - 多线程运行状态切换示例 <br/>
     */
    public class Demo2 {
        public static Thread thread1;
        public static Demo2 obj;
    
        public static void main(String[] args) throws Exception {
            // 第一种状态切换 - 新建 -> 运行 -> 终止
            System.out.println("#######第一种状态切换  - 新建 -> 运行 -> 终止################################");
            Thread thread1 = new Thread(new Runnable() {
                @Override
                public void run() {
                    System.out.println("thread1当前状态:" + Thread.currentThread().getState().toString());
                    System.out.println("thread1 执行了");
                }
            });
            System.out.println("没调用start方法,thread1当前状态:" + thread1.getState().toString());
            thread1.start();
            Thread.sleep(2000L); // 等待thread1执行结束,再看状态
            System.out.println("等待两秒,再看thread1当前状态:" + thread1.getState().toString());
            // thread1.start(); TODO 注意,线程终止之后,再进行调用,会抛出IllegalThreadStateException异常
    
            System.out.println();
            System.out.println("############第二种:新建 -> 运行 -> 等待 -> 运行 -> 终止(sleep方式)###########################");
            Thread thread2 = new Thread(new Runnable() {
                @Override
                public void run() {
                    try {// 将线程2移动到等待状态,1500后自动唤醒
                        Thread.sleep(1500);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    System.out.println("thread2当前状态:" + Thread.currentThread().getState().toString());
                    System.out.println("thread2 执行了");
                }
            });
            System.out.println("没调用start方法,thread2当前状态:" + thread2.getState().toString());
            thread2.start();
            System.out.println("调用start方法,thread2当前状态:" + thread2.getState().toString());
            Thread.sleep(200L); // 等待200毫秒,再看状态
            System.out.println("等待200毫秒,再看thread2当前状态:" + thread2.getState().toString());
            Thread.sleep(3000L); // 再等待3秒,让thread2执行完毕,再看状态
            System.out.println("等待3秒,再看thread2当前状态:" + thread2.getState().toString());
    
            System.out.println();
            System.out.println("############第三种:新建 -> 运行 -> 阻塞 -> 运行 -> 终止###########################");
            Thread thread3 = new Thread(new Runnable() {
                @Override
                public void run() {
                    synchronized (Demo2.class) {
                        System.out.println("thread3当前状态:" + Thread.currentThread().getState().toString());
                        System.out.println("thread3 执行了");
                    }
                }
            });
            synchronized (Demo2.class) {
                System.out.println("没调用start方法,thread3当前状态:" + thread3.getState().toString());
                thread3.start();
                System.out.println("调用start方法,thread3当前状态:" + thread3.getState().toString());
                Thread.sleep(200L); // 等待200毫秒,再看状态
                System.out.println("等待200毫秒,再看thread3当前状态:" + thread3.getState().toString());
            }
            Thread.sleep(3000L); // 再等待3秒,让thread3执行完毕,再看状态
            System.out.println("等待3秒,让thread3抢到锁,再看thread3当前状态:" + thread3.getState().toString());
    
        }
    }
    

    运行结果:


    #######第一种状态切换  - 新建 -> 运行 -> 终止################################
    没调用start方法,thread1当前状态:NEW
    thread1当前状态:RUNNABLE
    thread1 执行了
    等待两秒,再看thread1当前状态:TERMINATED
    
    ############第二种:新建 -> 运行 -> 等待 -> 运行 -> 终止(sleep方式)###########################
    没调用start方法,thread2当前状态:NEW
    调用start方法,thread2当前状态:RUNNABLE
    等待200毫秒,再看thread2当前状态:TIMED_WAITING
    thread2当前状态:RUNNABLE
    thread2 执行了
    等待3秒,再看thread2当前状态:TERMINATED
    
    ############第三种:新建 -> 运行 -> 阻塞 -> 运行 -> 终止###########################
    没调用start方法,thread3当前状态:NEW
    调用start方法,thread3当前状态:RUNNABLE
    等待200毫秒,再看thread3当前状态:BLOCKED
    thread3当前状态:RUNNABLE
    thread3 执行了
    等待3秒,让thread3抢到锁,再看thread3当前状态:TERMINATED
    
    Process finished with exit code 0
    

    相关文章

      网友评论

          本文标题:java并发之线程的运行状态

          本文链接:https://www.haomeiwen.com/subject/ejiaeqtx.html