>  기사  >  Java  >  Java 스레드 상태 및 의미

Java 스레드 상태 및 의미

WBOY
WBOY앞으로
2023-04-21 18:01:161154검색

자바 스레드의 현황을 이해해야 하는 이유

멀티스레딩과 높은 동시성은 중급 및 고급 개발자로 나아가기 위해 숙달해야 하는 능력입니다. 이 부분을 이해하기 전에 하늘 높이 솟아오릅니다. 가장 기본적인 개념, 즉 스레드의 상태가 무엇인지를 명확히 해야 합니다.

자바 스레드의 상태가 소스코드에서 어떤지 살펴보세요

오픈소스 정신 덕분에 직관적으로 분석하고 분석할 수 있습니다. Java에서 스레드의 상태를 확인하세요. 스레드의 모든 상태는 Java에 기록됩니다. 열거 클래스는

<code>java.lang.Thread.State</code> 

입니다. 소스 코드에서 Java에는 NEW, RUNNABLE, BLOCKED의 총 6가지 스레드 상태가 있음을 알 수 있습니다. , WAITING, TIMED_WAITING, TERMINATED 자세한 소스코드와 함께 다양한 스레드 상태의 의미를 살펴보겠습니다.

<code>public enum State {<br>    /**<br>     * 线程对象实例化但是还没有调用start方法.<br>     */<br>    NEW,<br><br>    /**<br>     * 线程处于可运行状态, 这个状态在虚拟机中<br>     * 看来是正在执行的, 但是实际可能在等待<br>     * 操作系统的资源, 比如等待CPU资源.<br>     * 注意Java线程状态只有RUNNABLE而没有RUNNING<br>     */<br>    RUNNABLE,<br><br>    /**<br>     * 阻塞状态的线程可能在等待获取锁,<br>     * 也可能是调用了wait方法后被notify方法<br>     * 唤醒, 再次尝试获取锁, 进入阻塞状态<br>     * {@link Object#wait() Object.wait}.<br>     */<br>    BLOCKED,<br><br>    /**<br>     * 等待状态, 此状态由于调用wait, join, park方法导致<br>     * <ul><br>     *   <li>{@link Object#wait() Object.wait} with no timeout</li><br>     *   <li>{@link #join() Thread.join} with no timeout</li><br>     *   <li>{@link LockSupport#park() LockSupport.park}</li><br>     * </ul><br>     *<br>     * 线程进入等待状态后, 等待notify, notifyAll,<br>     * 特定线程执行完毕, unpark方法<br>     * 然后转换为RUNNABLE状态<br>     */<br>    WAITING,<br><br>    /**<br>     * 有最大时间限制的等待状态<br>     * 可能由调用如下方法导致<br>     * <ul><br>     *   <li>{@link #sleep Thread.sleep}</li><br>     *   <li>{@link Object#wait(long) Object.wait} with timeout</li><br>     *   <li>{@link #join(long) Thread.join} with timeout</li><br>     *   <li>{@link LockSupport#parkNanos LockSupport.parkNanos}</li><br>     *   <li>{@link LockSupport#parkUntil LockSupport.parkUntil}</li><br>     * </ul><br>     */<br>    TIMED_WAITING,<br><br>    /**<br>     * 终止状态, 线程执行完毕后会进入<br>     * TERMINATED状态<br>     * 并且不能再转换成其它状态<br>     */<br>    TERMINATED;<br>}</code>  
  

10줄의 코드는 스레드의 6가지 상태를 소모합니다

메모리 향상을 위해 아래에서 설명합니다. 10개의 효과적인 코드를 사용하여 Java 스레드의 6가지 상태를 직관적으로 표시합니다.

<code>/**<br> * 如下展示了java线程的6种状态<br> * NEW 线程对象新创建还未start<br> * RUNNABLE 线程已经启动, 线程在JVM中正在运行, 不过在系统层面可能在等待系统资源<br> * BLOCKED 线程等待获取锁<br> * WAITING 线程被LockSupport#park(),<br> * Object#wait()或者Thread.join, 等待被unpark或者notify或者其他新城join完毕<br> * TIMED_WAITING 线程sleep或者wait(long),<br> * LockSupport#parkNanos LockSupport.parkNanos, 等待指定时间后继续执行<br> * TERMINATED 线程执行完毕, 已经被终止<br> * @throws BrokenBarrierException<br> * @throws InterruptedException<br> */<br>@Test<br>public void testThreadStatus() throws BrokenBarrierException, InterruptedException {<br>    CyclicBarrier cyclicBarrier = new CyclicBarrier(2);<br>    Thread thread = new Thread(() -> {<br>        try {<br>            LockSupport.park(this);<br>            TimeUnit.SECONDS.sleep(5);<br>            synchronized (ThreadTest.class) {<br>                // 尝试获取锁, 获取不到进入Blocked状态等待锁<br>            }<br>            cyclicBarrier.await();<br>        } catch (InterruptedException e) {<br>            e.printStackTrace();<br>        } catch (BrokenBarrierException e) {<br>            e.printStackTrace();<br>        }<br>    });<br>    log.info("线程创建还未启动, 状态为: {}", thread.getState());<br>    thread.start();<br>    log.info("线程已经启动, 状态为: {}", thread.getState());<br>    TimeUnit.SECONDS.sleep(1);<br>    log.info("线程已经park, 状态为: {}", thread.getState());<br>    LockSupport.unpark(thread);<br>    TimeUnit.SECONDS.sleep(3);<br>    log.info("线程启动后进入sleep状态, 状态为: {}", thread.getState());<br>    synchronized (ThreadTest.class) {<br>        // 前面sleep了4秒, 5到7秒main线程持有锁.<br>        // 子线程第6秒开始获取锁, 但需要等待main线程释放锁, 此时子线程是BLOCKED状态<br>        TimeUnit.SECONDS.sleep(3);<br>        log.info("线程等待锁, 状态为: {}", thread.getState());<br>    }<br>    cyclicBarrier.await();<br>    log.info("线程已经执行结束, 状态为: {}", thread.getState());<br>}</code> 

실행 결과는

<code>- 线程创建还未启动, 状态为: NEW<br>- 线程已经启动, 状态为: RUNNABLE<br>- 线程已经park, 状态为: WAITING<br>- 线程启动后进入sleep状态, 状态为: TIMED_WAITING<br>- 线程等待锁, 状态为: BLOCKED<br>- 线程已经执行结束, 状态为: TERMINATED</code>

스레드 상태 변환

번거로운 흐름도를 피하고 스레드 상태의 상호 변환에 대해 간략하게 설명하겠습니다.

  1. new runnable로 변환될 수 있습니다

  2. runnable은 차단 또는 대기로 변환될 수 있습니다. timed_waiting A

  3. 차단되거나 대기 중이면 timed_waiting 상태는 조건이 충족된 후 실행 가능으로 변환될 수 있습니다

  4. 스레드가 완료된 후 실행하면 종료상태가 됩니다

위 내용은 Java 스레드 상태 및 의미의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제