Java并发编程学习15-深入探索任务关闭机制(非正常线程终止与JVM关闭详解)

引言

在软件开发中,任务关闭是一个至关重要的环节,它关乎到应用程序的稳定性和资源的有效管理。在之前的篇章中,我们已经初步探讨了任务关闭的一些基本概念和原则。然而,任务关闭的复杂性在于,它不仅仅涉及到正常情况下的资源释放,还需要处理各种异常情况,如非正常的线程终止以及JVM的关闭。这些异常情况如果处理不当,可能会导致资源泄露、数据丢失甚至系统崩溃。因此,本文将深入探索非正常线程终止的处理机制以及JVM关闭时的注意事项,帮助开发者更好地掌握任务关闭的精髓,确保应用程序能够优雅地处理各种关闭场景。

Read More

Java并发编程学习14-探索基于线程的服务如何优雅关闭

引言

我们知道,应用程序通常会创建拥有多个线程的服务,例如线程池,并且这些服务的生命周期通常比创建它们的方法的生命周期更长。如果应用程序准备退出,那么这些服务所拥有的线程也需要结束。由于无法通过抢占式的方法来停止线程,因此它们需要自行结束。

线程应该有一个相应的所有者,即创建该线程的类。而线程池就是其工作者线程的所有者,如果要停止这些线程,那么应当通过线程池来操作。

应用程序可以拥有服务,服务也可以拥有工作者线程,但应用程序并不能拥有工作者线程,因此应用程序不能直接停止工作者线程。

Read More

Java并发编程学习11-任务执行演示

引言

上一篇博文带大家了解了任务执行和 Executor 框架的基础知识,本篇将结合这些内容,演示一些不同版本的任务执行Demo,并且每个版本都实现了不同程度的并发性。

以下的示例是要实现浏览器程序中的页面渲染功能:将 HTML 页面绘制到图像缓存中【为了简便,假设 HTML 页面只包含标签文本、预定义大小的图片和URL】。

Read More

Java并发编程学习10-任务执行与Executor框架

任务执行

何为任务? 任务通常是一些抽象且离散的工作单元。

大多数并发应用程序都是围绕着 “任务执行” 来构造的。而围绕着 “任务执行” 来设计应用程序结构时,首先要做的就是要找出清晰的任务边界。大多数服务器应用程序都提供了一种自然的任务边界选择方式:以独立的客户请求为边界。将独立的请求作为任务边界,既可以实现任务的独立性,又可以实现合理的任务规模。

Read More

Java并发编程学习8-同步工具类(闭锁、信号量和栅栏)

引言

同步工具类可以是任意一个对象,只要它根据其自身的状态来协调线程的控制流。阻塞队列可以作为同步工具类,类似地还有信号量(Semaphore)栅栏(Barrier)以及闭锁(Latch)。当然 Java 平台类库中还有其他的一些同步工具类,如果这些都不能满足要求,那我们还可以创建自己的同步工具类【这块内容将在后续的博文中会介绍】。

同步工具类封装了一些状态,这些状态将决定执行同步工具类的线程是继续执行还是等待,此外还提供了一些方法对状态进行操作,以及另一些方法用于高效地等待同步工具类进入到预期状态。

Read More

Java并发编程学习7-阻塞队列

引言

介绍阻塞队列之前,先来介绍下队列 QueueQueue 用来临时保存一组等待处理的元素。它提供了几种非阻塞队列实现,如下:

  • ConcurrentLinkedQueue,这是一个传统的先进先出队列。
  • PriorityQueue,这是一个(非并发的)优先队列。

如上两个队列的操作不会阻塞,如果队列为空,那么获取元素的操作将返回空值。

Read More