[ISSUE #4095] Code Optimization and Interrupeted Exception handling.

issue介绍

tag: first good issue

地址:github.com/apache/even...

Code Optimization and Interrupeted Exception handling in EtcdCustomService.class

对EtcdCustomService类的变量以及InterrupetedException处理的优化

知识点

Interrupeted Exception

大家先看下面这段代码:

1.创建一个Runnable类

Java 复制代码
public class InterruptedRunnable implements Runnable {
    @Override
    public void run() {
        Thread currentThread = Thread.currentThread();
        while(true){
            if(currentThread.isInterrupted()){
                break;
            }

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

2.运行的时候对它进行中断

Java 复制代码
public class Main {

    public static void main(String[] args) {
        InterruptedRunnable interruptedRunnable = new InterruptedRunnable();
        Thread interruptedThread = new Thread(interruptedRunnable);
        interruptedThread.start();
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        interruptedThread.interrupt();
    }

}

可以观察到两点:

1.Interrupted Exception

2.线程当前还在运行

上述代码明明调用了线程的interrupt()方法来中断线程,但是却并没有起到啥作用。原因是线程的run()方法在执行的时候,大部分时间都是阻塞在sleep(100)上,当其他线程通过调用执行线程的interrupt()方法来中断执行线程时,大概率的会触发InterruptedException异常。

如何正确处理Interrupeted Exception

在触发InterruptedException异常的同时,JVM会同时把线程的中断标志位清除,所以,这个时候在run()方法中判断的currentThread.isInterrupted()会返回false,也就不会退出当前while循环了。

处理InterruptedException异常时要小心,如果在调用执行线程的interrupt()方法中断执行线程时,抛出了InterruptedException异常,则在触发InterruptedException异常的同时,JVM会同时把执行线程的中断标志位清除,此时调用执行线程的isInterrupted()方法时,会返回false。此时,正确的处理方式是在执行线程的run()方法中捕获到InterruptedException异常,并重新设置中断标志位(也就是在捕获InterruptedException异常的catch代码块中,重新调用当前线程的interrupt()方法)。 我们在类的catch中进行一个中断标志位的设置

Java 复制代码
try {
    Thread.sleep(100);
} catch (InterruptedException e) {
    e.printStackTrace();
    currentThread.interrupt();
}

主线程就会运行结束:

pr过程中注意的事项

  1. fork到自己的仓库然后创建对应的分支解决问题 比如git checkout -b fix_patch_4508
  2. checkstyle一定要配置好,不然ci必报错(一个小空格都会报错),ci会检查你commit的文件
  3. 提PR的时候注意格式(标题、正文带解决的issue (Fixs #xxx))

参考对应的官方文档: eventmesh.apache.org/zh/communit...

------------开源小白 希望不断积累

相关推荐
用户37215742613520 分钟前
Java 实现 Excel 与 TXT 文本高效互转
java
算家计算28 分钟前
7B参数拿下30个世界第一!Hunyuan-MT-7B本地部署教程:腾讯混元开源业界首个翻译集成模型
人工智能·开源
FIT2CLOUD飞致云1 小时前
SQLBot开源智能问数系统成功进入GitHub趋势榜主榜,Star数突破2,000个!
开源
bobz9651 小时前
virtio vs vfio
后端
浮游本尊1 小时前
Java学习第22天 - 云原生与容器化
java
Rexi1 小时前
“Controller→Service→DAO”三层架构
后端
bobz9652 小时前
计算虚拟化的设计
后端
深圳蔓延科技2 小时前
Kafka的高性能之路
后端·kafka
Barcke2 小时前
深入浅出 Spring WebFlux:从核心原理到深度实战
后端
JuiceFS2 小时前
从 MLPerf Storage v2.0 看 AI 训练中的存储性能与扩展能力
运维·后端