华为技术专家深度解析Java线程状态(下)

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 华为技术专家深度解析Java线程状态

4 等待

  • 等待线程的线程状态。

image.png

处于等待状态的线程正在等待另一个线程执行特定操作。


例如:

  • 一个在对象上调用Object.wait()的线程正在等待另一个线程在该对象上调用Object.notify()或Object.notifyAll() 。这样便可以控制线程的执行顺序。
  • Thread.join()的线程正在等待指定的线程终止
  • 线程拥有对象锁后进入到相应的代码区后,调用相应的“锁对象”的wait()后产生的一种结果

进入条件

由于调用以下方法之一,线程处于等待状态:

  • Object.wait()
  • LockSupport.park()
  • Thread join( )

它们也是在等待另一个对象事件的发生,也就是描述了等待的意思。

WAIT V.S BLOCKED

  • BLOCKED
    JVM认为程序还不能进入某区域,因为同时进去就会有问题,这是一块临界区
  • wait()
    先决条件是要进入临界区,即线程已经拿到“凭证”,自己可能进去做了一些事情,但此时通过判定某些业务上的参数,发现还有一些其他配合的资源没有准备充分,那么自己就等等再做其他事


典型案例就是通过wait()/notify()完成生产者/消费者模型。

当生产者生产过快,发现仓库满了,即消费者还没有把东西拿走(空位资源还没准备好) 时,生产者就等待有空位再做事。

消费者拿走东西时会发出“有空位了”的消息,那么生产者就继续工作。

反之,当消费者消费过快发现没有存货时,消费者也会等存货到来,生产者生产出内容后发出“有存货了”的消息,消费者才继续抢东西。


这种状态下,若发生了对该线程的interrupt()是有用的,处于该状态的线程内部会抛InerruptedException,该异常应当在run()里面捕获,使得run()正常执行完成。

在run()内部捕获异常后,还可以让线程继续运行,根据具体场景决定。


这种状态下,若某线程对该锁对象做了notify(),则将从等待池中唤醒一个线程重新恢复到RUNNABLE。

除notify()外,还有一个notifyAll() ,前者是唤醒一个处于WAITING的线程,而后者是唤醒所有的线程。


Object.wait()是否需要死等呢?

image.png

不是,除中断外,它还有两个重构方法


  • Object.wait(int timeout)

传入的timeout 参数是超时的毫秒值,超过该值后会自动唤醒,继续做下面的操作(不会抛InterruptedException ,但是并不意味着我们不去捕获,因为不排除其他线程会对它做interrup())

  • Object.wait(int timeout,int nanos)
    更精确的超时设置,可以精确到纳秒,这个纳秒值可接受的范围是0~999999 (因为100000onS 等于1ms)。

同样的

LockSupport park( )

LockSupport.parkNanos( )

LockSupport.parkUntil( )

Thread.join()


这些方法都会有类似的重构方法来设置超时,达到类似的目的,不过此时的状态不再是WAITING,而是TIMED.WAITING

通常写代码的人肯定不想让程序死掉,但是又希望通过这些等待、通知的方式来实现某些平衡,这样就不得不去尝试采用“超时+重试+失败告知”等方式来达到目的。

5 TIMED_WAITING

image.png

当调用Thread.sleep()时,相当于使用某个时间资源作为锁对象,进而达到等待的目的,当时间达到时触发线程回到工作状态。

进入条件

  • LockSupport parkNanos(long nanos)
  • LockSupport parkUntil(long deadline)


这个线程对象也许是活的,但是,它已经不是一个单独执行的线程,在一个死去的线程上调用start()方法,会抛java.lang.IllegalThreadStateException。


线程run()、main() 方法执行结束,或者因异常退出了run()方法,则该线程结束生命周期。死亡的线程不可再次复生。


run()走完了,线程就处于这种状态。其实这只是Java 语言级别的一种状态,在操作系统内部可能已经注销了相应的线程,或者将它复用给其他需要使用线程的请求,而在Java语言级别只是通过Java 代码看到的线程状态而已。

为什么wait( )notify( )必须要使用synchronized

如果不用就会报ilegalMonitorStateException,常见写法如下:

synchronized(Object){
  object.wait() ;//object.notify() ;
}
synchronized(this){
  this.wait();
}
synchronized fun( ){
  this.wait();//this.notify();
}

wait()notify()是基于对象存在的。

  • 为什么要基于对象存在呢?
    既然要等,就要考虑等什么,这里等待的就是一个对象发出的信号,所以要基于对象而存在

不用对象也可以实现,比如suspend()/resume()就不需要,但是它们是反面教材,表面上简单,但特别容易死锁。


所以目前它调用的方式只能是Object.wait(),这样才能和对象挂钩。但这些东西还与问题“wait()/notify() 为什么必须要使用synchronized" 没有半点关系,或者说与对象扯上关系,为什么非要用锁呢?


既然是基于对象的,就得用个数据结构存放这些等待的线程,该数据结构应当与该对象绑定(查看JVM代码,可知该数据结构为一个双向链表),此时在这个对象上可能同时有多个线程调用wait()/notify(),在向这个对象所对应的双向链表中写入、删除数据时,依然存在并发的问题,理论上也需要一个锁来控制。在JVM 内核源码中并没有发现任何自己用锁来控制写入的动作,只是通过检查当前线程是否为对象的OWNER 来判定是否要抛异常。由此可见它希望该动作由Java 程序代码自己控制,为什么JVM不选择自己控制锁呢?

因为有时更低抽象层次的锁不是好事,这样的请求对于外部可能是反复循环地去征用,或这些代码还可能在其他地方复用,也许将它粗粒度化会更好一些,而且这样的代码在写在Java 程序中也更加清晰,容易看到相互之间的关系。


interrupt()操作只对处于WAITING TIMED_WAITING 状态的线程有用,让它们产生实质性的异常抛出。

通常如果线程处于运行中状态,也不会让它中断,如果中断是成立的,可能会导致正常的业务运行出现问题。另外,如果不想用强制手段,就得为每条代码的运行设立检查,但是这个动作很麻烦,JVM 不愿意做这件事情,它做interrupt()仅仅是打一个标记,此时程序中通过isInterrupt()方法能够判定是否被发起过中断操作,如果被中断了,那么如何处理程序就是设计问题。


比如,若代码运行是一个死循环,则在循环中可以这样:

while(true) {
  if (Thread.currentThread.isInterrupt()) {
  //可做类似的break、return,抛出InterruptedException 达到某种目的,这完全由自己决定
  //如拋出异常,通常包装一层try catch 异常处理,进一步做处理,如退出run或什么也不做
  }
}
  • 这太麻烦了,为什么不可以自动呢?
    可以这么理解:当你发现门外有人呼叫你,你自己是否愿意搭理他是你的事情,这是一种有“爱”的沟通方式,反之是暴力地破门而入,把你强制“抓”出去


/

JDK 6 及以后,可以使用线程的interrupted( )

image.png

判定线程是否已经被调用过中断方法,表面上的效果与isInterrupted()

image.png

结果一样,不过这是个静态方法。


此外,这个方法调用后将会重新将中断状态置false,方便循环利用线程,而不是中断后状态就始终为true,就无法将状态修改回来了。


对应的,判定线程的相关方法有isAlive()

image.png

6 Terminated

  • 最后,再回顾一个线程的状态图

1.png

目录
相关文章
|
18天前
|
人工智能 自然语言处理 Java
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
FastExcel 是一款基于 Java 的高性能 Excel 处理工具,专注于优化大规模数据处理,提供简洁易用的 API 和流式操作能力,支持从 EasyExcel 无缝迁移。
88 9
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
|
4天前
|
SQL Java 数据库连接
如何在 Java 代码中使用 JSqlParser 解析复杂的 SQL 语句?
大家好,我是 V 哥。JSqlParser 是一个用于解析 SQL 语句的 Java 库,可将 SQL 解析为 Java 对象树,支持多种 SQL 类型(如 `SELECT`、`INSERT` 等)。它适用于 SQL 分析、修改、生成和验证等场景。通过 Maven 或 Gradle 安装后,可以方便地在 Java 代码中使用。
92 11
|
3天前
|
存储 分布式计算 Hadoop
基于Java的Hadoop文件处理系统:高效分布式数据解析与存储
本文介绍了如何借鉴Hadoop的设计思想,使用Java实现其核心功能MapReduce,解决海量数据处理问题。通过类比图书馆管理系统,详细解释了Hadoop的两大组件:HDFS(分布式文件系统)和MapReduce(分布式计算模型)。具体实现了单词统计任务,并扩展支持CSV和JSON格式的数据解析。为了提升性能,引入了Combiner减少中间数据传输,以及自定义Partitioner解决数据倾斜问题。最后总结了Hadoop在大数据处理中的重要性,鼓励Java开发者学习Hadoop以拓展技术边界。
23 7
|
25天前
|
存储 缓存 Java
Java 并发编程——volatile 关键字解析
本文介绍了Java线程中的`volatile`关键字及其与`synchronized`锁的区别。`volatile`保证了变量的可见性和一定的有序性,但不能保证原子性。它通过内存屏障实现,避免指令重排序,确保线程间数据一致。相比`synchronized`,`volatile`性能更优,适用于简单状态标记和某些特定场景,如单例模式中的双重检查锁定。文中还解释了Java内存模型的基本概念,包括主内存、工作内存及并发编程中的原子性、可见性和有序性。
Java 并发编程——volatile 关键字解析
|
24天前
|
移动开发 前端开发 Java
Java最新图形化界面开发技术——JavaFx教程(含UI控件用法介绍、属性绑定、事件监听、FXML)
JavaFX是Java的下一代图形用户界面工具包。JavaFX是一组图形和媒体API,我们可以用它们来创建和部署富客户端应用程序。 JavaFX允许开发人员快速构建丰富的跨平台应用程序,允许开发人员在单个编程接口中组合图形,动画和UI控件。本文详细介绍了JavaFx的常见用法,相信读完本教程你一定有所收获!
Java最新图形化界面开发技术——JavaFx教程(含UI控件用法介绍、属性绑定、事件监听、FXML)
|
10天前
|
监控 JavaScript 数据可视化
建筑施工一体化信息管理平台源码,支持微服务架构,采用Java、Spring Cloud、Vue等技术开发。
智慧工地云平台是专为建筑施工领域打造的一体化信息管理平台,利用大数据、云计算、物联网等技术,实现施工区域各系统数据汇总与可视化管理。平台涵盖人员、设备、物料、环境等关键因素的实时监控与数据分析,提供远程指挥、决策支持等功能,提升工作效率,促进产业信息化发展。系统由PC端、APP移动端及项目、监管、数据屏三大平台组成,支持微服务架构,采用Java、Spring Cloud、Vue等技术开发。
|
23天前
|
Java 数据库连接 Spring
反射-----浅解析(Java)
在java中,我们可以通过反射机制,知道任何一个类的成员变量(成员属性)和成员方法,也可以堆任何一个对象,调用这个对象的任何属性和方法,更进一步我们还可以修改部分信息和。
|
8月前
|
SQL Java 数据库连接
Java从入门到精通:3.1.2深入学习Java EE技术——Hibernate与MyBatis等ORM框架的掌握
Java从入门到精通:3.1.2深入学习Java EE技术——Hibernate与MyBatis等ORM框架的掌握
|
8月前
|
存储 设计模式 算法
Java从入门到精通:2.1.1深入学习Java核心技术——掌握Java集合框架
Java从入门到精通:2.1.1深入学习Java核心技术——掌握Java集合框架
|
8月前
|
算法 Java 程序员
论文翻译 | 【深入挖掘Java技术】「底层原理专题」深入分析一下并发编程之父Doug Lea的纽约州立大学的ForkJoin框架的本质和原理
本文深入探讨了一个Java框架的设计、实现及其性能。该框架遵循并行编程的理念,通过递归方式将问题分解为多个子任务,并利用工作窃取技术进行并行处理。所有子任务完成后,其结果被整合以形成完整的并行程序。 在总体设计上,该框架借鉴了Cilk工作窃取框架的核心理念。其核心技术主要聚焦于高效的任务队列构建和管理,以及工作线程的管理。经过实际性能测试,我们发现大多数程序的并行加速效果显著,但仍有优化空间,未来可能需要进一步研究改进方案。
94 3
论文翻译 | 【深入挖掘Java技术】「底层原理专题」深入分析一下并发编程之父Doug Lea的纽约州立大学的ForkJoin框架的本质和原理

热门文章

最新文章

推荐镜像

更多