抛出异常,是不是错误处理的第一选择

Java 语言支持三种异常的状况:非正常异常(Error),运行时异常(Runtime Exception)和检查型异常(Checked Exception)。

异常状况的处理会让代码的效率变低,所以我们不应该使用异常机制来处理正常的状况。一个流畅的业务,理想的情况是,在执行代码时没有任何异常发生。否则,业务执行的效率就会大打折扣。

改进方案:共用错误码

js 复制代码
public sealed interface Returned<T> {
    record ReturnValue<T>(T returnValue) implements Returned {
    }
    
    record ErrorCode(Integer errorCode) implements Returned {
    }
}    

在这个改进的设计里,我们使用了封闭类。我们知道封闭类的子类是可以穷举的,这是这项改进需要的一个重要特点。我们把 Returned 的许可类(ReturnValue 和 ErrorCode)定义成档案类,分别表示返回值和错误代码。这样,我们就有了一个精简的方案。

一个方法,返回的要么是返回值,要么是错误码,而不是同时返回两个值。

js 复制代码
public static Returned<Digest> of(String algorithm) {
    return switch (algorithm) {
        case "SHA-256" -> new ReturnValue(new SHA256());
        case "SHA-512" -> new ReturnValue(new SHA512());
        case null, default -> new ErrorCode(-1);
    };
}

返回 ReturnValue 这个许可类,就表示没有错误;返回 ErrorCode 这个许可类,就表示出现错误。这样的设计,就变得简单、皮实多了。

种方式仍然具有一些缺陷,例如它本身没有携带调试信息。在 Java 的错误处理方面,我们希望未来能够有更好的设计和更多的探索,让我们的代码更完善。


此文章为9月Day10学习笔记,内容来源于极客时间《深入剖析 Java 新特性》

相关推荐
掘金者阿豪9 分钟前
Django接金仓数据库:我踩过的坑和填坑指南
后端
_风满楼20 分钟前
HTTP 请求的五种传参方式
前端·javascript·后端
码事漫谈30 分钟前
为什么 token 计费规则里,输出比输入贵那么多
后端
Go_error33 分钟前
Go database/sql 基于临时 channel 传递连接
后端·go
Go_error42 分钟前
Go 循环栅栏
后端·go
程序员老邢1 小时前
【产品底稿 07】商助慧 Admin 运维模块落地:从 “能跑” 到 “能运维”,3 个页面搞定日常排障
java·运维·经验分享·spring boot·后端
彩票管理中心秘书长1 小时前
npm 依赖管理机制完全解析(超详细版)
后端
彩票管理中心秘书长1 小时前
npm 脚本与自动化完全指南(超详细版)
后端
元宝骑士1 小时前
Spring @Async 异步无法获取当前登录用户?Sa-Token 1.34.0 终极踩坑解决方案
java·后端
鱼人1 小时前
Fibers(纤程)来了:打破阻塞,实现纯PHP下的异步非阻塞IO
后端