文档章节

中断状态与InterruptedExceptin异常的相互转换

恶魔在江湖
 恶魔在江湖
发布于 2014/02/18 15:03
字数 734
阅读 53
收藏 0

调用interrupt方法后,可以中断掉线程。这里所说中断掉线程,是指下面其中一种结果。

(1)线程变成“中断状态”对“状态”的反应;

(2)抛出“异常InterruptedException”对“控制”的反应。

通常会使(1)。只有在线程是sleep、wait、join时会是(2)(这个时候不会变成中断状态)。

然而,状态(1)、(2)是可以相互转换的。也就是说,可以把(1)变为(2),也可以把(2)变为(1)。配合程序的需要——大致上就是为了让程序不至于忘记被中断的事实——而加以变化。

下面是具体的说明:

中断状态 -> InterruptedException异常的转换

“若线程是中断状态,就抛出InterruptedException异常”,可以像下面这样写。其中interrupted方法,是java.lang.Thread类的类方法。

if(Thread.interrupted()){
    throw new InterruptedException();
}

在花时间的处理前,先加上这个if语句,可提高程序对中断的响应性。可以避免不知道自己已经被中断,还开始进行花时间的处理。

反倒是,这个if语句乍看之下很简单,要完全了解倒比想象中复杂许多。

哪个线程来检查interrupted方法

Thread.interrupted方法,会检查Thread.currentThread()的中断状态。也就是说,上面的if语句无论卸载哪个类的哪个方法,都是检查执行if语句的线程的中断状态。

不想清除中断状态的时候

调用Thread.interrupted方法后,线程就不是中断状态了。也就是说,只要调用一次Thread.interrupted方法后,中断状态就会被清除。

如果不想清除中断状态,而要检查现在线程是否被中断,要使用isInterrupted实例方法。调用方式如下:

if(Thread.currentThread.isInterrupted()){
    //若为中断中断时需要进行的处理(中断状态不会清除)
}

InterruptedException异常 -> 转换为中断状态

想要让线程只有在指定的时间才停止时,可以使用Thread.sleep方法。因为Thread.sleep会抛出InterruptedException异常,所以可能我们需要经常会这样写:

try {
    Thread.sleep(1000);
} catch (InterruptedException e){
}

不过,这样写的话,抛出的InterruptedException异常会被忽略。当sleep被其他线程interrupt时,“被中断”这个事实会消失。

若当我们不希望被中断这个事实消失时,就像下面这样,自己再重新中断自己一次。

try {
    Thread.sleep(1000);
} catch (InterruptedException e) {
    Thread.currentThread.interrupt();
}

这样可以将收到的InterruptedException异常转换为中断状态的形式。

InterruptedException异常 -> 转换为InterruptedException异常

收到的InterruptedException异常,也可以不马上抛出来,而留下来晚点再抛。如下:

  InterruptedException savedException = null;
  ...
  
  try {
      Thread.sleep(1000);
  } catch (InterruptedException e) {
      savedException = e;
  }
  ...
  if (savedException != null){
      throw savedException;
  }

在这里,先将收到的InterruptedException存在变量savedException里,留到后面才throw出去。

内容来源于《Java多线程设计模式》一书,方便以后查看。

© 著作权归作者所有

共有 人打赏支持
恶魔在江湖
粉丝 5
博文 19
码字总数 7329
作品 0
朝阳
程序员
私信 提问
FutureTask在线程池中应用和源码解析

原文出处:hcy0411 FutureTask 是一个支持取消的异步处理器,一般在线程池中用于异步接受callable返回值。 主要实现分三部分: 封装 Callable,然后放到线程池中去异步执行->run。 获取结果-...

hcy0411
2018/11/20
0
0
JUC锁框架——CyclicBarrier

CyclicBarrier的简单介绍 CyclicBarrier是一个同步辅助类,它允许一组线程相互等待,直到到达某个公共屏障点(common barrier point)。通过它可以完成多个线程之间相互等待,只有当每个线程...

长头发-dawn
2018/09/17
0
0
内功修炼之操作系统学习(二:处理器管理)

处理器管理 处理器管理是操作系统的重要组成部分,它负责调度、管理和分配处理器并控制程序的执行。处理器管理中最重要的是处理器调度,即进程调度,也就是控制、协调进程对处理器的竞争。为...

长平狐
2012/10/08
222
0
JAVA Thread的中断机制(interrupt)

Thread的中断机制(interrupt) 中断线程 线程的thread.interrupt()方法是中断线程,将会设置该线程的中断状态位,即设置为true,中断的结果线程是死亡、还是等待新的任务或是继续运行至下一步...

北极心
2015/11/20
0
0
关闭线程的正确姿势,实现“优雅”的中断

width="603px" src="http://ss.csdn.net/p?http://mmbiz.qpic.cn/mmbizjpg/pzKp1L04Evjtj54s91X3o5fiaOukoCHaF3qd1AOQZEcZrViaM2mpJ9SWbp5ialqZpRiaQaxYR9AnUNwDcx6tHHmdzQ/640?wxfmt=jpeg&w......

bjweimengshu
2017/12/28
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Spark in action on Kubernetes - Playground搭建与架构浅析

前言 Spark是非常流行的大数据处理引擎,数据科学家们使用Spark以及相关生态的大数据套件完成了大量又丰富场景的数据分析与挖掘。Spark目前已经逐渐成为了业界在数据处理领域的行业标准。但是...

阿里云官方博客
9分钟前
0
0
小白大数据学习路线

学习大数据首先了解大数据技术得板块划分: 数据计算(离线计算):Hadoop、spark 数据计算(实时计算):storm、spartstreaming、flink 其他框架:zookeeper 数据采集:flume、Kafka 数据存...

董黎明
22分钟前
0
0
mariadb 内存占用优化

本文由云+社区发表 作者:工程师小熊 摘要:我们在使用mariadb的时候发现有时候不能启动起来,在使用过程中mariadb占用的内存很大,在这里学习下mariadb与内存相关的配置项,对mariadb进行调...

腾讯云加社区
今天
2
0
spring security 自定义登录认证

spring security 自定义认证登录 1.概要 1.1.简介 spring security是一种基于 Spring AOP 和 Servlet 过滤器的安全框架,以此来管理权限认证等。 1.2.spring security 自定义认证流程 1)认证...

EasyProgramming
今天
1
0
Win下Jenkins-2.138源码编译及填坑笔记

源码编译篇 1、 安装JDK1.8-181,操作系统添加JDK环境变量。Java -version验证一下。 注:Jenkins2.138版本,JDK必须jkd1.8.0-101以上,不支持Java9,Maven必须3.5.3以上。 2、 解压Maven3....

编程SHA
今天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部