自定义异常及枚举类使用
自定义异常
理解error、RuntimeException(运行时,虚拟机报的错)和非RuntimeException(编译时,编译器找出的错)
1.java中异常均继承自Throwable,其有两个重要的直接子类error与exception.
2.java错误error,大部分是由虚拟机爆出来的错误,是程序无法处理的错误,如OutOfMemoryError,当JVM需要更多内存空间而得不到满足时,就会爆出OutOfMemoryError。
3.Exception,异常,其下分类很多,如可查异常与不可查异常,运行时异常与非运行时异常,基本概念一样,只是说法不同罢了。其有个重要的子类即RuntimeException运行时异常,其它直接子类都归为非RuntimeException,如IOException,SQLException等。
a.非RuntimeException是在代码书写时,编译器给你检查提示你要进行try catch或throws处理。
b.RuntimeException,编译器不会帮你自动检查,当你运行程序时,虚拟机才会给你爆出错误让你去处理,这个往往是我们编码逻辑或不规范导致的
自定义异常,步骤,三步走:
1.继承RuntimeException
2.重载构造函数
3.重写方法
比如:
public class SellException extends RuntimeException{
1.继承RuntimeException
private Integer code; //异常码,类似于状态码,前端根据code作相应处理
public SellException(ResultEnum resultEnum) {2.重载构造函数
super(resultEnum.getMessage());
this.code = resultEnum.getCode();
}
public SellException(Integer code, String message) {
super(message);
this.code = code;
}
}
用法:throw new SellException(ResultEnum.PRODUCT_NOT_EXSIT);
使用枚举对象封装常量
枚举对象为enum类型,
步骤:
1.创建构造函数,参数为常量值和常量含义
2.创建枚举对象
@Getter
public enum OrderStatusEnum implements CodeEnum {
NEW(0, "新订单"),
FINISHED(1, "完结"),
CANCEL(2, "已取消"),
;
private Integer code;
private String message;
OrderStatusEnum(Integer code, String message) {
this.code = code;
this.message = message;
}
}
相关文章
- springboot - 解决使用pagehelper 报 SQL语句异常
- 【异常】 'ascii' codec can't decode byte 0xe8 in position 2: ordinal not in range(128)
- 重学c#系列——盛派自定义异常源码分析(八)
- python自定义异常实例详解
- 重学c#系列——盛派自定义异常源码分析(八)
- Atitit mysql数据库自定义异常在java里面的捕获与处理推荐标准与规范
- Java编程常见内存溢出异常与代码示例
- 【异常】SpringCloud Gateway网关自定义过滤器无法获取到请求体body的内容?不存在的!
- 〖Python零基础入门篇㊹〗- 自定义异常 [raise 关键字]
- 【Python3网络爬虫开发实战】3.1.2-处理异常
- 孤立森林异常检测算法原理和实战(附代码)
- 有关于异常捕获点滴,plus我也揭揭apache-common的短
- 利用自定义异常来重构代码(▄︻┻┳═一不了解自定义异常者勿看)
- 向QtableWidget中添加自定义widget崩溃异常: 0xC0000005
- 第十二章 linux-中断-ARM异常
- 使用IDA查看汇编代码上下文去辅助排查C++软件异常问题
- C++软件异常分析与排查的学习历程
- 使用GAN 进行异常检测——anoGAN,TODO,待用于安全分析实验
- 建立自己的异常类方式
- Hbase常见异常hbase:meta,,1.1588230740 is NOT online; state={1588230740 state=OPEN, ts=162
- Spring MVC统一异常处理的3种方式(附带实例)
- 【异常】java11提示: Cannot find any provider supporting RSA/ECB/PKCS1Padding的问题
- 【异常】Flink整合ES出错,The implementation of the provided ElasticsearchSinkFunction is not serializable.
- 产品新说 | 指标的异常检测怎么做,能更好配合业务变化(二)