当前位置: 首页 > news >正文

【java 线程的状态】

介绍

Java 线程在运⾏的⽣命周期中的指定时刻只可能处于下⾯ 6 种不同状态的其中⼀个状态

状态名称说明
NEW初始状态,线程被构建,但是还没有调用start()方法
RUNNABLE运行状态,Java线程将操作系统中的就绪和运行两种状态统称为"运行中"
BLOCKED阻塞状态,表示线程阻塞于锁
WAITING等待状态,表示线程进入等待状态,进入该状态表示当前线程需要其他线程通知(notify或者notifyAll)
TIME_WAITING超时等待状态,可以指定等待时间自己返回
TERMINATED终止状态,表示当前线程已经执行完毕

查看Thread类中定义了一个State枚举类型

public enum State {/*** Thread state for a thread which has not yet started.*/NEW,RUNNABLE,BLOCKED,WAITING,TIMED_WAITING,TERMINATED;}

各种状态的demo

NEW

    public void test1() { //NEWThread t1 = new Thread(() -> {System.out.println("Thread1~~~~");});System.out.println(t1.getState());}

这个时候线程刚刚创建,还没有调用start()方法,所以状态为NEW

TERMINATED

    @Testpublic void test2() throws InterruptedException { //TERMINATEDThread t1 = new Thread(() -> {System.out.println("线程开始执行");System.out.println("线程结束执行");});t1.start();Thread.sleep(3000);System.out.println(t1.getState());}

线程执行结束后查看状态为TERMINATED,加sleep是为了保证在getState的时候线程已经执行结束

RUNNABLE

    @Testpublic void test3() { //RUNNABLEThread t1 = new Thread(() -> {});t1.start();System.out.println(t1.getState());}

调用了start()方法后线程处于RUNNABLE状态。

注意:线程创建之后它将处于 NEW(新建) 状态,调⽤ start() ⽅法后开始运⾏,线程这时候处于READY(可运⾏) 状态。可运⾏状态的线程获得了 cpu 时间⽚(timeslice)后就处于RUNNING(运⾏) 状态。操作系统隐藏 Java 虚拟机(JVM)中的 READY 和 RUNNING 状态,它只能看到 RUNNABLE 状态。所以Java系统把这两个状态统称为RUNNABLE状态。

BLOCKED

这边我们模拟一个我们模拟找桌子用餐的场景 学生1和学生2同时争夺一个座位用餐,学生一先抢到座位,学生2就处于阻塞的状态,只能等待学生1用餐结束

public class Test1 {public static void main(String[] args) throws InterruptedException {System.out.println(Thread.currentThread().getName());Table table = new Table();Thread student1 = new Thread(() -> {table.use();}, "s1");Thread student2 = new Thread(() -> {table.use();}, "s2");student1.start();Thread.sleep(1000);student2.start();Thread.sleep(500);System.out.println(student2.getState());}
}
class Table { public synchronized void use() {System.out.println(Thread.currentThread().getName() + "-使用桌子");try {Thread.sleep(2000);} catch (InterruptedException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName() + "就餐结束");}
}

WAITING

这边我们模拟学生1在得到座位后发现自己忘记点餐了,所以只能让出座位这个资源。进入wait状态

public class Test2 {public static void main(String[] args) throws Exception {System.out.println(Thread.currentThread().getName());Table1 table = new Table1();Thread student1 = new Thread(() -> {try {table.use();} catch (Exception e) {e.printStackTrace();}}, "s1");student1.start();Thread.sleep(100);System.out.println(student1.getState());Thread.currentThread().getState();}
}class Table1 { public synchronized void use() throws Exception {System.out.println(Thread.currentThread().getName() + "-使用桌子");//忘记点餐了System.out.println("忘记点餐了");wait(100);Thread.sleep(2000);System.out.println(Thread.currentThread().getName() + "就餐结束");}
}

TIME_WAITING

这个在WAITING的基础上加了一个自动返回的时间,就算没有其他线程通知它,过了一定的时间它也会自动返回。

http://www.lryc.cn/news/377844.html

相关文章:

  • php加密验签
  • 【Golang - 90天从新手到大师】Day06 - 数组
  • java的有参构造方法
  • Vue66-vue-默认插槽
  • tsf-consul的使用
  • 【perl】基本语法 /备忘录/
  • mongodb 集群安装
  • 绿茶集团重启IPO:流量渐退、业绩波动,还能讲出好故事吗?
  • Git与SSH
  • 我的创作纪念日--码农阿豪
  • Git 学习笔记(超详细注释,从0到1)
  • GitLab项目组相关操作(创建项目组Group、创建项目组的项目、为项目添加成员并赋予权限)
  • 英语恶补ing
  • DS1339C串行实时时钟-国产兼容RS4C1339
  • 神经网络模型---LeNet-5
  • 免费分享:1994-2020年中国各行业二氧化碳排放数据(附下载方法)
  • Qemu虚拟机在线迁移到VMware
  • 计算机游戏因为d3dcompiler_47.dll丢失无法启动怎么办?解决只要d3dcompiler_47.dll丢失无法启动游戏软件的方法
  • LDO的原理及测试方法
  • 图论算法学习
  • 面试题——RabbitMQ
  • 前端开发之浏览器垃圾回收机制
  • less-loader的less转成CSS的底层原理
  • 解锁Flutter中的ProcessResult:让外部命令执行变得轻松
  • 第二十五篇——信息加密:韦小宝说谎的秘诀
  • Redis 主从复制+哨兵+集群
  • cpolar:通过脚本自动更新主机名称和端口号进行内网穿透【免费版】
  • 【Python日志模块全面指南】:记录每一行代码的呼吸,掌握应用程序的脉搏
  • SpringBoot 多种优雅的线程池配置与使用(异步执行函数,反射机制,动态识别参数,有返回值)
  • ansible copy模块--持续创作中