简单的例子理解java线程的生命周期
来源:互联网 发布:手机在线网页聊天源码 编辑:程序博客网 时间:2024/06/01 12:31
线程的生命周期图如下:
这些状态在java.lang.Thread类中是以枚举的形式定义的
public enum State {/**至今尚未启动的线程的状态。*/NEW,/**可运行线程的线程状态。处于可运行状态的某一线程正在 Java 虚拟机中运行,但它可能正在等待操作系统中的其他资源,比如处理器。*/RUNNABLE,/**受阻塞并且正在等待监视器锁的某一线程的线程状态。处于受阻塞状态的某一线程正在等待监视器锁,以便进入一个同步的块/方法,或者在调用Object.wait之后再次进入同步的块/方法。*/BLOCKED,/**某一等待线程的线程状态。某一线程因为调用下列方法之一而处于等待状态:不带超时值的 Object.wait不带超时值的 Thread.joinLockSupport.park处于等待状态的线程正等待另一个线程,以执行特定操作。 例如,已经在某一对象上调用了 Object.wait() 的线程正等待另一个线程,以便在该对象上调用 Object.notify() 或 Object.notifyAll()。已经调用了 Thread.join() 的线程正在等待指定线程终止。*/WAITING,/**具有指定等待时间的某一等待线程的线程状态。某一线程因为调用以下带有指定正等待时间的方法之一而处于定时等待状态:Thread.sleep带有超时值的 Object.wait带有超时值的 Thread.joinLockSupport.parkNanosLockSupport.parkUntil */TIMED_WAITING,/**已终止线程的线程状态。线程已经结束执行。*/TERMINATED;}
以下代码是一个简单的小例子:
public class Main {private static class Runner implements Runnable {@Overridepublic void run() {try {System.out.println("sleep...");Thread.sleep(10);System.out.println("yield...");Thread.yield();} catch (InterruptedException e) {e.printStackTrace();}}}public static void main(String[] args) throws InterruptedException {Thread t = new Thread(new Runner());System.out.println(t.getState());t.start();System.out.println(t.getState());while (t.isAlive()) {System.out.println(t.getState());}System.out.println(t.getState());}}
输出:
NEWRUNNABLERUNNABLERUNNABLERUNNABLEsleep...BLOCKEDTIMED_WAITING(此处省略八百多行的TIMED_WAITING)TIMED_WAITINGyield...BLOCKEDRUNNABLETERMINATED
0 0
- 简单的例子理解java线程的生命周期
- java 线程的简单例子
- Java线程的生命周期的深入理解
- 线程的生命周期 - 理解Java中线程的状态
- Activity生命周期简单的例子
- Java线程死锁的简单例子
- 线程的简单例子
- 最简单的例子理解java回调
- Java线程总结(八):并发包------读写锁ReadWriteLock的简单例子详细理解
- JAVA线程的生命周期
- Java线程的生命周期
- JAVA线程的生命周期
- java 线程的生命周期
- java线程的生命周期
- Java线程的生命周期
- Java线程的生命周期
- Java线程的生命周期
- Java线程的生命周期
- 基于Kubernetes构建Docker集群管理详解
- navisworks ViewControl在WPF中的使用
- mui开发APP教程之仿天猫支付弹出自定义框
- .axf 转化 .bin文件 的方法
- json
- 简单的例子理解java线程的生命周期
- 数据结构之线性表
- 读书笔记_Effective_C++_条款十一:在operator=中处理自我赋值
- 网格模型obj文件及其纹理解析
- 欢迎使用CSDN-markdown编辑器
- vue2.0学习——组件开发01
- HDU 3709 Balanced Number(数位DP)
- 修改jenkins主目录与cp参数a使用
- Mysql在5.1+事件调度器(Event Scheduler)