多线程—线程状态转换

 如图,单箭头代表不可逆转,双箭头代表可以互相转换。

序号1、NEW->RUNNABLE

当调用线程的start()方法时,由NEW——>RUNNABLE。

序号2、RUNNABLE<——>WAITING

  • 线程使用synchronized(object)获取对象之后。

  • Object调用wait()方法时,线程从RUNNABLE——>WAITING

  • Object调用notify(),notifyAll(),interrupt()时

    如果线程竞争成功,线程从WAITING——>RUNNABLE

    如果线程竞争失败,线程从WAITING——>BLOCKED

序号3、RUNNABLE<——>WAITING

当线程调用t.join()方法时,当前线程从RUNNABLE——>WAITING

注意:此时是当前线程在t线程对象的Monitor上等待

当t线程运行结束时,或者是调用了当前线程的interrupt()方法时,当前线程从WAITING——>RUNNABLE

序号4、RUNNABLE<——>WAITING

当线程调用LockSupport.par()方法时,线程从RUNNABLE——>WAITING

调用LockSupport.unpar(线程对象)方法或调用线程的interrupt(),会让目标线程从WAITING——>RUNNABLE

序号5、RUNNABLE<——>TIMED_WAITING

当t线程用synchronized(obj)获取对象锁后

  • Object调用wait(long n)方法时,t线程从RUNNABLE——>TIMED_WAITING

  • 当t线程等待时间超过了n毫秒,或者object对象调用了notify(),notifyAll(),interrupt()时

    • 竞争锁成功之后,t线程从TIMED_WAITING——>RUNNABLE

    • 竞争锁失败之后,t线程从TIMED_WAITING——>BLOCKED

序号6、RUNNABLE<——>TIMED_WAITING

当线程调用t.join(long n)方法时,当前线程从RUNNABLE——>TIMED_WAITING

  • 注意当前线程是在t线程对象的Monitor上等待。

当前线程等待时间超过n毫秒,或者t线程结束,或者调用了当前线程的interrupt()方法时,当前线程从TIMED_WAITING——>RUNNABLE

序号7、RUNNABLE<——>TIMED_WAITING

当前线程调用了Thread.sleep(long n),当前线程从RUNNABLE——>TIMED_WAITING

当前线程等待时间超过了n毫秒,当前线程从TIMED_WAITING——>RUNNABLE

序号8、RUNNABLE<——>TIMED_WAITING

当线程调用LockSupport。partNanos(long nanos)或LockSupport.parkUntil(long millis)时,当前线程从RUNNABLE——>TIMED_WAITING

调用LockSupport.unpark(线程对象)或调用线程的interrupt(),或是等待超时,会让目标线程从TIMED_WAITING——>RUNNABLE

序号9、RUNNABLE<——>BLOCKED

t线程用synchronized(object)获得了对象锁时,如果竞争失败,从RUNNABLE——>BLOCKED

当持有 object对象锁的线程的同步代码块执行完毕,会唤醒该对象上所有BLOCKED的线程重新竞争,如果t线程竞争成功,从BLOCKED——>RUNNABLE

序号10、RUNNABLE——>TERMINATED

当线程的所有代码执行完毕,进入到TERMINATED

Guess you like

Origin blog.csdn.net/qq_42251944/article/details/120879693