自定义异常的简单实现
自定义异常
1. 程序错误:
2. 异常分类
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-IzIIheAj-1595419297869)(C:\Users\Gp\AppData\Roaming\Typora\typora-user-images\image-20200721114601210.png)]
Throwable :Error 和Exception 的父类,错误和异常,错误是无法处理的,异常可以通过程序处理
返回异常发生时的详细信息
public string getMessage();
返回异常发生时的简要描述
public string toString();
返回异常对象的本地化信息。使用Throwable的子类覆盖这个方法,可以声称本地化信息。如果子类没有覆盖该方法,则该方法返回的信息与getMessage()返回的结果相同
public string getLocalizedMessage();
在控制台上打印Throwable对象封装的异常信息
public void printStackTrace();
Error:程序无法处理的错误,表示运行应用程序中较严重问题。大多数错误与代码编写者执行的操作无关,而表示代码运行时 JVM(Java 虚拟机)出现的问题。例如,Java虚拟机运行错误(Virtual MachineError),当 JVM 不再有继续执行操作所需的内存资源时,将出现 OutOfMemoryError。这些异常发生时,Java虚拟机(JVM)一般会选择线程终止。这些错误表示故障发生于虚拟机自身、或者发生在虚拟机试图执行应用时,如Java虚拟机运行错误(Virtual MachineError)、类定义错误(NoClassDefFoundError)等。这些错误是不可查的,因为它们在应用程序的控制和处理能力之 外,而且绝大多数是程序运行时不允许出现的状况。对于设计合理的应用程序来说,即使确实发生了错误,本质上也不应该试图去处理它所引起的异常状况。在 Java中,错误通过Error的子类描述。
Exception:我们主要处理部分,所有异常信息的父类,
Exception(异常):是程序本身可以处理的异常。Exception 类有一个重要的子类 RuntimeException。RuntimeException 类及其子类表示“JVM 常用操作”引发的错误。例如,若试图使用空值对象引用、除数为零或数组越界,则分别引发运行时异常(NullPointerException、ArithmeticException)和 ArrayIndexOutOfBoundException。
Exception(异常)分两大类:运行时异常和非运行时异常(编译异常)。程序中应当尽可能去处理这些异常。
1.运行时异常:都是RuntimeException类及其子类异常,如NullPointerException(空指针异常)、IndexOutOfBoundsException(下标越界异常)等,这些异常是不检查异常,程序中可以选择捕获处理,也可以不处理。这些异常一般是由程序逻辑错误引起的,程序应该从逻辑角度尽可能避免这类异常的发生。运行时异常的特点是Java编译器不会检查它,也就是说,当程序中可能出现这类异常,即使没有用try-catch语句捕获它,也没有用throws子句声明抛出它,也会编译通过。
2.非运行时异常 (编译异常):是RuntimeException以外的异常,类型上都属于Exception类及其子类。从程序语法角度讲是必须进行处理的异常,如果不处理,程序就不能编译通过。如IOException、SQLException等以及用户自定义的Exception异常,一般情况下不自定义检查异常。
3. 自定义异常
package com.gp.common.exception;
import lombok.Data;
/**
* @time 2020/6/29 16:45
* @Author gp
* 自定义异常类
*/
@Data
public class CommonExcepiton extends RuntimeException {
private static final long serialVersionUID = 1L;
private String msg;
private Integer code;
public CommonExcepiton() {
super();
}
public CommonExcepiton(String message) {
this.msg=messages;
}
public CommonExcepiton(Integer code,String msg){
this.msg =msg;
this .code =code;
}
public CommonExcepiton(String msg,Throwable e){
super(msg,e);
this.msg =msg;
}
@Override
public String getMessage() {
return msg;
}
// 关键 减少异常打印
@Override
public Throwable fillInStackTrace() {
return this;
}
}
那么如何使用异常,需要在需要处理异常的地方 使用 抛出相应的异常:
@RequestMapping("/test")
@ResponseBody
public String test() {
String username ="user";
if (username.length()<10){
throw new CommonExcepiton("用户名长度不能小于10");
}
return "username is right";
}
结果:
定义异常的全局捕捉类:
/**
* @time 2020/7/22 18:42
* @Author gp
* 异常的全局捕捉
*/
@RestController
@ControllerAdvice
public class ExceptionController {
@ExceptionHandler(CommonExcepiton.class)
public Result commExcepiton(){
return Result.errorResult();
}
}
再次调用test结果:
转载:博客链接 异常信息转载该博客
版权声明:本文为CSDN博主「王晓(Java)」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。