如图,单箭头代表不可逆转,双箭头代表可以互相转换。
序号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