自定义异常及枚举类使用

自定义异常

理解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,编译器不会帮你自动检查,当你运行程序时,虚拟机才会给你爆出错误让你去处理,这个往往是我们编码逻辑或不规范导致的


20160827100639473.png

自定义异常,步骤,三步走
    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 findOne(Example var1);没有入参为String/Integer的API,后来排查发现是版本问题,当下使用的是2点几的版本,应该使用 1.5.3.RELEASE
改用版本后,发现了API:T findOne(ID var1);

你可能感兴趣的:(自定义异常及枚举类使用)