自定义异常及枚举类使用

自定义异常

理解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;
    }
}

转载于:https://www.cnblogs.com/h-c-g/p/11225034.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值