java基础篇 之 异常丢失

简介: java基础篇 之 异常丢失

我们看如下代码:

@Slf4j
public class Test {
    public static void main(String[] args) {
        try {
            try {
                test();
            } finally {
                test2();
            }
        } catch (Exception e) {
            System.out.println(e.getMessage());
        }
    }
    public static void test() {
        System.out.println("test方法执行了");
        throw new RuntimeException("veryImportant exception");
    }
    public static void test2() {
        System.out.println("test2");
        throw new CustomeException("common exception");
    }
}

执行结果如下:


我们可以看到,在执行的适合,一个veryImportant exception丢失了,而抛出了一个common exception,这是相当严重的缺陷,因为异常可能会以一种比前面例子所示更微妙和难以察觉的方式完全丢失。相比之下,C++把“前一个异常还没处理就抛出下一个异常”的情形看成是糟糕的错误。


一种更加糟糕的编程手法如下所示:

package com.study.spring.transaction.controller;
import com.study.spring.transaction.CustomeException;
import lombok.extern.slf4j.Slf4j;
/**
 * @Author: dmz
 * @Description:
 * @Date: Create in 2:40 2019/4/21
 */
@Slf4j
public class Test {
    public static void main(String[] args) {
        try {
            try {
                test();
            } finally {
                return;
            }
        } catch (Exception e) {
            System.out.println(e.getMessage());
        }
    }
    public static void test() {
        System.out.println("test方法执行了");
        throw new RuntimeException("veryImportant exception");
    }
    public static void test2() {
        System.out.println("test2");
        throw new CustomeException("common exception");
    }
}

可以看到,在finally快中,我们直接将函数返回了,这个适合执行代码,会发现,即使抛出了异常,也不会有任何输出。

这种情况下我们怎么办呢?我觉得主要就是多加日志,虽然程序不会主动输出什么,但是我们可以在出现错误的地方自己打印日志

@Slf4j
public class Test {
    public static void main(String[] args) {
        try {
            try {
                test2();
            } finally {
                return;
            }
        } catch (Exception e) {
            System.out.println(e.getMessage());
        }
    }
    public static void test() {
        System.out.println("test方法执行了");
        throw new RuntimeException("veryImportant exception");
    }
    public static void test2() {
        System.out.println("test2");
        CustomeException common_exception = new CustomeException("common exception");
        log.error("test2调用失败", common_exception);
        throw common_exception;
    }

调用结果:

test2
00:46:09.508 [main] ERROR com.study.spring.transaction.controller.Test - test2调用失败
com.study.spring.transaction.CustomeException: common exception
  at com.study.spring.transaction.controller.Test.test2(Test.java:33)
  at com.study.spring.transaction.controller.Test.main(Test.java:16)
Process finished with exit code 0
相关文章
|
2月前
|
Java 开发者 UED
【实战宝典】Java异常处理大师级教程:throws关键字,让异常声明成为你的专属标签!
【实战宝典】Java异常处理大师级教程:throws关键字,让异常声明成为你的专属标签!
48 3
|
10天前
|
存储 缓存 Java
java基础:IO流 理论与代码示例(详解、idea设置统一utf-8编码问题)
这篇文章详细介绍了Java中的IO流,包括字符与字节的概念、编码格式、File类的使用、IO流的分类和原理,以及通过代码示例展示了各种流的应用,如节点流、处理流、缓存流、转换流、对象流和随机访问文件流。同时,还探讨了IDEA中设置项目编码格式的方法,以及如何处理序列化和反序列化问题。
38 1
java基础:IO流 理论与代码示例(详解、idea设置统一utf-8编码问题)
|
1天前
|
安全 Java 数据安全/隐私保护
如何配置 Java 安全管理器来避免访问控制异常
配置Java安全管理器以防止访问控制异常,需在启动JVM时通过 `-Djava.security.manager` 参数启用,并设置安全策略文件,定义权限规则,限制代码执行操作,确保应用安全。
|
8天前
|
Java
让星星⭐月亮告诉你,Java异常分类[Throwable(Error/Exception(RuntimeException/其他异常)) 检查时异常 非检查时异常]
本文深入解析了Java异常处理机制,重点介绍了`Throwable`类及其子类`Error`和`Exception`,并通过实例代码、流程图和表格详细解释了异常的分类、区别及处理方法,帮助读者掌握异常处理的关键技巧,提升程序的稳定性和健壮性。
24 1
|
12天前
|
Java 程序员
关于java异常
关于java异常
18 5
|
13天前
|
Java 程序员 编译器
Java中的异常类型
Java中的异常类型
19 3
|
1月前
|
Java 编译器 数据库连接
Java——异常
在 Java 中,程序执行过程中的不正常行为被称为异常。异常分为 Error 和 Exception。Error 表示系统级错误,而 Exception 则封装程序可能出现的问题。异常包括编译时异常和运行时异常(如数组越界)。异常可用于查找 bug 信息和作为方法内部的特殊返回值。处理异常的方式有默认处理和捕获异常,后者通过 try-catch 结构实现。此外,还可以自定义异常类来更灵活地处理特定情况。
32 9
Java——异常
|
12天前
|
存储 Java 编译器
【一步一步了解Java系列】:认识异常类
【一步一步了解Java系列】:认识异常类
19 2
|
16天前
|
Java 程序员 编译器
Java中的异常类型
Java中的异常类型
16 3
|
17天前
|
Java
Java异常捕捉处理和错误处理
Java异常捕捉处理和错误处理
17 1