线程的五种状态(操作系统层面)
- 初始状态:创建线程,分配资源,但还没有调度到就绪队列。
- 就绪状态:线程已经被创建,等待获取cpu调度执行。
- 运行状态:正在使用cpu执行的状态,当时间片用完,会由运行态变为就绪态。
- 阻塞状态:线程暂时丢失cpu使用权的状态,比如发生io操作 等待锁。
- 终止状态:线程已经执行完毕。
线程的六种状态(java层面)
- 新建状态 NEW,线程创建之后还没有调用start方法就是这种状态。
- 运行状态 RUNNABLE:它包含了操作系统层面的就绪 运行 以及io阻塞状态,在Java中都称为运行状态。
- 终止状态 TERMINATED:对应操作系统中的线程终止状态。
- 有限期等待状态TIMED_WAITING:有时限的等待状态。
- 无限期等待状态WAITING:没有时限的等待状态
- 阻塞状态 BLOCKED:等待获取锁的状态。
操作系统线程状态与Java线程状态区别
- Java的运行状态包含了操作系统的就绪,运行,io阻塞三个状态。
- 操作系统的阻塞状态包含了Java运行态中的io等待,有时限等待,无时限等待,等待锁。
- io阻塞在Java属于运行状态,在操作系统属于阻塞状态。
线程状态转换的几种情况
-
new状态的t线程调用自身的start方法,自身进入runable状态。
-
runnable状态的t线程调用锁对象的wait方法,自身进入waiting状态,当其他线程调用 obj.notify obj.notifyall t.interrupt方法时,当前t线程会去竞争锁,竞争成功进入runnable状态,竞争失败进入blocked状态。
-
runnable状态的t线程调用b线程的a.join()方法时,当前t线程会进入waiting状态,当a线程执行完毕,或其他线程调用当前t线程的 t.interrupt方法时,当前线程会进入runnable状态。
-
runnable状态的t线程调用 LockSupport.park()方法时,当前线程进入waiting状态,当其他线程调用LockSupport.park()方法或t.interrupt方法时,当前线程会进入runnable状态。
-
runnable状态的t线程调用锁对象的wait(n)方法,当前线程进入timed_waiting状态,当当前t线程等待了n毫秒或其他线程调用 obj.notify obj.notifyall t.interrupt方法时,当前t线程会去竞争锁,竞争成功进入runnable状态,竞争失败进入blocked状态。
-
runnable状态的t线程调用b线程的a.join(n)方法时,当前t线程会进入timed_waiting状态,当当前t线程等待了n毫秒或当a线程执行完毕 其他线程调用当前t线程的 t.interrupt方法时,当前线程会进入runnable状态。
-
runnable状态的t线程调用自身线程的sleep(n)方法,当前线程会进入timed_waiting状态,当当前t线程等待了n毫秒或其他线程调用当前t线程的 t.interrupt方法时,当前线程会进入runnable状态。
-
t线程使用synchronized(obj)获取对象锁时如果竞争失败,从runnable进入blocked状态。
-
当前线程执行结束或发生异常,进入terminated状态。
线程状态示例
- 示例
Thread t1 = new Thread(()->{
log.info("runing");
});
log.info("t1状态:"+t1.getState()); //NEW
------------