自定义异常
理解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;
}
}
使用框架要注意版本
在使用spring data jpa时,发现只有 <S extends T> S findOne(Example<S> var1);没有入参为String/Integer的API,后来排查发现是版本问题,当下使用的是2点几的版本,应该使用 <version>1.5.3.RELEASE</version>
改用版本后,发现了API:T findOne(ID var1);