本篇内容主要讲解“java线程状态有哪些几种”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“java线程状态有哪些几种”吧!
多线程高并发是初级开发者迈向中高级开发者必须要掌握的能力, 万丈高楼平地起, 在深入了解这部分内容前, 我们要明确最基本的概念, 即线程有哪些状态.
得益于开源精神, 我们可以直观的分析看到在Java中, 线程到底有哪些状态. Java中记录线程所有状态的枚举类为
java.lang.Thread.State
从源代码中我们可以看到在Java中线程总共有6种状态NEW, RUNNABLE, BLOCKED, WAITING, TIMED_WAITING, TERMINATED. 下面我们来看一下详细的源代码, 以及各种线程状态的含义.
public enum State { /** * 线程对象实例化但是还没有调用start方法. */ NEW, /** * 线程处于可运行状态, 这个状态在虚拟机中 * 看来是正在执行的, 但是实际可能在等待 * 操作系统的资源, 比如等待CPU资源. * 注意Java线程状态只有RUNNABLE而没有RUNNING */ RUNNABLE, /** * 阻塞状态的线程可能在等待获取锁, * 也可能是调用了wait方法后被notify方法 * 唤醒, 再次尝试获取锁, 进入阻塞状态 * {@link Object#wait() Object.wait}. */ BLOCKED, /** * 等待状态, 此状态由于调用wait, join, park方法导致 * <ul> * <li>{@link Object#wait() Object.wait} with no timeout</li> * <li>{@link #join() Thread.join} with no timeout</li> * <li>{@link LockSupport#park() LockSupport.park}</li> * </ul> * * 线程进入等待状态后, 等待notify, notifyAll, * 特定线程执行完毕, unpark方法 * 然后转换为RUNNABLE状态 */ WAITING, /** * 有最大时间限制的等待状态 * 可能由调用如下方法导致 * <ul> * <li>{@link #sleep Thread.sleep}</li> * <li>{@link Object#wait(long) Object.wait} with timeout</li> * <li>{@link #join(long) Thread.join} with timeout</li> * <li>{@link LockSupport#parkNanos LockSupport.parkNanos}</li> * <li>{@link LockSupport#parkUntil LockSupport.parkUntil}</li> * </ul> */ TIMED_WAITING, /** * 终止状态, 线程执行完毕后会进入 * TERMINATED状态 * 并且不能再转换成其它状态 */ TERMINATED;}
为了增强记忆, 下面我们用10句有效代码, 直观的把Java线程的6种状态展示出来.
/** * 如下展示了java线程的6种状态 * NEW 线程对象新创建还未start * RUNNABLE 线程已经启动, 线程在JVM中正在运行, 不过在系统层面可能在等待系统资源 * BLOCKED 线程等待获取锁 * WAITING 线程被LockSupport#park(), * Object#wait()或者Thread.join, 等待被unpark或者notify或者其他新城join完毕 * TIMED_WAITING 线程sleep或者wait(long), * LockSupport#parkNanos LockSupport.parkNanos, 等待指定时间后继续执行 * TERMINATED 线程执行完毕, 已经被终止 * @throws BrokenBarrierException * @throws InterruptedException */@Testpublic void testThreadStatus() throws BrokenBarrierException, InterruptedException { CyclicBarrier cyclicBarrier = new CyclicBarrier(2); Thread thread = new Thread(() -> { try { LockSupport.park(this); TimeUnit.SECONDS.sleep(5); synchronized (ThreadTest.class) { // 尝试获取锁, 获取不到进入Blocked状态等待锁 } cyclicBarrier.await(); } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } }); log.info("线程创建还未启动, 状态为: {}", thread.getState()); thread.start(); log.info("线程已经启动, 状态为: {}", thread.getState()); TimeUnit.SECONDS.sleep(1); log.info("线程已经park, 状态为: {}", thread.getState()); LockSupport.unpark(thread); TimeUnit.SECONDS.sleep(3); log.info("线程启动后进入sleep状态, 状态为: {}", thread.getState()); synchronized (ThreadTest.class) { // 前面sleep了4秒, 5到7秒main线程持有锁. // 子线程第6秒开始获取锁, 但需要等待main线程释放锁, 此时子线程是BLOCKED状态 TimeUnit.SECONDS.sleep(3); log.info("线程等待锁, 状态为: {}", thread.getState()); } cyclicBarrier.await(); log.info("线程已经执行结束, 状态为: {}", thread.getState());}
执行结果为
- 线程创建还未启动, 状态为: NEW- 线程已经启动, 状态为: RUNNABLE- 线程已经park, 状态为: WAITING- 线程启动后进入sleep状态, 状态为: TIMED_WAITING- 线程等待锁, 状态为: BLOCKED- 线程已经执行结束, 状态为: TERMINATED
下面我们避免繁琐的流程图, 简单描述下下线程状态的相互转换.
到此,相信大家对“java线程状态有哪些几种”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
原文链接:https://my.oschina.net/u/4599684/blog/4455208