Throwable -抛出异常类与自定义异常类
/*
自定义异常类
java提供的异常类,不够我们使用,需要自己定义一些异常类
格式:
public class XXXException extends Exception/runtimeException{
添加一个空参数的构造方法
添加一个带异常信息的构造方法
}
注:
1.自定义异常类一般是Exception结尾,说明该类是一个异常类
2.必须继承Exception/RuntimeException
*/
public class RegisterException extends Exception {
//添加一个带空参数的异常
public RegisterException() {
} //查看异常源码可知,可以让父类的构造方法来解决异常信息
public RegisterException(String message) {
super(message);
} }
import java.util.Scanner; /**
* 利用异常,模拟注册功能
*/ public class IsRegister {
//1.数组保存已经注册的用户名(数据库)
static String[] usename = {"赵", "王", "孙"}; public static void main(String[] args) /*throws RegisterException*/ {
//2.一般从前端获取数据源
Scanner sc = new Scanner(System.in);
System.out.println("请输入用户名: ");
String name = sc.nextLine();
checkUsename(name); }
//3.定义一个方法对用户输入的数据进行判断
public static void checkUsename(String name) /*throws RegisterException*/ {
for (String usename : usename) {
if(usename.equals(name)){
try {
throw new RegisterException("用户已注册"); //运行期异常,可以不用throws和try catch
} catch (RegisterException e) {
e.printStackTrace();
return;//结束
}
}
}
//注册成功
System.out.println("注册成功");
}
}
/*
//Throwable所有异常的超类
Exception -编译异常,可以throws或者try{}catch{} -子类
RuntimeException -运行异常,可以不处理,让JVM处理
Error -无法处理,必须修改源代码,内存溢出,系统崩溃 -子类
异常处理过程:方法里面异常,查看有没有异常处理逻辑,若没有
——把内容,原因,位置报告JVM——找到方法的调用者(main)
——查看有没有异常处理逻辑,若没有——返回给JVM,JVM控制台打印,并且中断程序 //运行时异常
throw关键字
作用:可以使用throw关键字在指定的方法中抛出指定的异常
格式:throw new xxxException("异常产生的原因")
注:1.throw关键字必须在方法的内部
2.throw关键字new的必须是Exception或其子类对象
3.throw关键字抛出指定的异常对象,我们必须处理这个对象
1.throw关键字后边创建的是RuntimeException或其子类对象,可以交给JVM(打印异常+中断程序)
2.throw关键字后边创建的是编译异常(写代码的时候),要么throws,要么try catch
工作中,必须对对方传递过来的方法进行合法化校验,不合法,则抛出异常的方式给到调用者 //编译异常
throws关键字:异常处理的第一种方式,交给被人处理
作用:
当方法的内部抛出异常对象的时候,那么我们就必须处理这个异常对象
throws将异常对象声明(内容,原因,位置)给调用者,自己不处理,最终会交付给JVM
格式:
修饰符 返回值类型 方法名(参数列表)throws XXXException,XXX,XXX{
throw new XXXException("异常的原因")
}
注意:throws 后面的异常声明必须是Exception或其子类
方法内部如果有多个异常对象,throws必须声明多个
如果异常对象有子父类对象,直接声明父类异常即可
此外,如一旦声明抛出异常的方法,就必须处理该异常,要么继续在调用对象throws声明异常,最后交给方法调用者最后交给JVM,中断
要么try...catch自己处理(一般这种比较好)不中断 try catch:异常处理的第二种方式,自己处理
格式:try{
可能异常的代码
}catch(定义一个异常变量接受try中异常变量){
异常处理逻辑,工作中会把信息记录进日志
}
...
catch(定义一个异常变量接受try中异常变量){
异常处理逻辑,工作中会把信息记录进日志
}
注:try中可能有对个异常对象,所以需要多个catch来处理
如果try中产生异常,就会执行catch的异常处理逻辑,继续执行之后的代码
如果catch里的异常类有父子类关系,子类应该写在上边(二义性),Exception所有的异常类 finally
格式:try{
可能异常的代码
}catch(定义一个异常变量接受try中异常变量){
异常处理逻辑,工作中会把信息记录进日志
}
...
catch(定义一个异常变量接受try中异常变量){
异常处理逻辑,工作中会把信息记录进日志
}finally{
无论代码是否出现异常,这里都会执行
}
注:finally不能单独使用,必须与try一起用,finally一般用于资源释放,无论程序是否有异常,均需要释放资源 */ import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.List; public class Throwable {
public static void main(String[] args) /*throws IOException*/ {
//RuntimeException可以不用自己处理交给JVM
//int[] num=new int[5];
//getElement(num,6); //编译异常,需要自己处理,使用throws
//readFile("c:\\b.txt");不会执行,因为上面的异常JVM让程序已经中断 //使用try catch
try {
readFileC("c:\\b.txt"); //有可能出现异常的代码
} catch (ArrayIndexOutOfBoundsException e) {//throws声明的什么异常,就用来生成对象来接收
//异常处理逻辑
/*
Throwable类中定义了三个方法:
String toString() - 返回此 throwable 的详细消息字符串。
StackTraceElement[] getStackTrace() - 提供编程访问由 printStackTrace() 输出的堆栈跟踪信息,JVM打印默认调用此方法
String getMessage() -返回此 throwable 的简短描述。
*/
System.out.println(e.toString()); //java.lang.ArrayIndexOutOfBoundsException: Index 4 out of bounds for length 3
System.out.println(e.getMessage()); //Index 4 out of bounds for length 3
System.out.println(e.getStackTrace()); //[Ljava.lang.StackTraceElement;@4e50df2e
}finally {
System.out.println("资源释放"); //finally无论是否异常,均执行
}
System.out.println("劳资没有中断,太强了"); } public static void getElement(int[] arr, int index) { //运行期异常,可以不用自己处理
if (index > 4 || index < 0) {
throw new ArrayIndexOutOfBoundsException("数组索引有问题"); //ArrayIndexOutOfBoundsException运行期异常,交给JVM,不用自己throw
}
//在Objects里有个判断NullPointerException的方法可以判断 对象 是否为空,简化上述代码
//格式Objects.requireNonNull(对象名);
//另一个重载Objects.requireNonNull(对象名,"抛出的信息") } /*
定义一个方法,对传递的文件路径合法化判断,使用throws
由于FileNotFoundException extends IOException
所以声明IOException即可
*/
public static void readFile(String src) throws IOException {
//抛出文件位置异常
if (!src.equals("c:\\a.txt")) {
throw new FileNotFoundException("文件位置不匹配");
}
//抛出文件后缀异常
if (!src.endsWith(".txt")) {
throw new IOException("文件位置不匹配"); }
} public static void readFileC(String src) {
List<Integer> integers = List.of(1, 2, 3);
integers.get(4); }
}
Throwable -抛出异常类与自定义异常类的更多相关文章
- Java异常类和自定义异常类
自定义异常类: public class ExtendsException extends Exception { private static final long serialVersionUID ...
- C# 自定义异常类 throw语句抛出异常
Exception概述: 异常(Exception)一般分为两大类SystemException.ApplicationException,前者是预定义的异常类,后者是用户自定义异常类时需要继承的类 ...
- [转]如何编写和应用Java的自定义异常类
编写自定义异常类实际上是继承一个API标准异常类,用新定义的异常处理信息覆盖原有信息的过程.常用的编写自定义异常类的模式如下: public class CustomException exten ...
- java中自定义异常类
hello,大家好,今天跟大家分享一下java中如何自定义异常,以后如果有新的心得,再添加,欢迎前辈指导... 首先,上Api,看一下异常和错误的父类: 然后,现在假设我有个循环(i=0;i<1 ...
- java基础之自定义异常类及throw和throws的区别
一.异常的架构: Throwable类:所以异常类都是Throwable的子类,它派生两个子类 Error和Exception. Error类:表示仅靠程序本身无法恢复的的严重错误,比如内存溢出,虚拟 ...
- 【java】自定义异常类
目录结构: contents structure [+] 为什么需要自定义异常类 自定义异常的方式 实例 日常日志 一,为什么需要自定义异常类 当java中的异常类型没有能够满足我们所需的异常的时候就 ...
- java的自定义异常类
编写自定义异常类的模式 编写自定义异常类实际上是继承一个Exception标准异常类,用新定义的异常处理信息覆盖原有信息的过程.常用的编写自定义异常类的模式如下: public classCustom ...
- java -> 异常类与自定义异常
异常 什么是异常?Java代码在运行时期发生的问题就是异常. 在Java中,把异常信息封装成了一个类.当出现了问题时,就会创建异常类对象并抛出异常相关的信息(如异常出现的位置.原因等). 异常的继承体 ...
- Java自定义异常类
用户可以根据自己的需要定义自己的异常类,定义异常类只需要继承Exception类即可 //================================================= // Fi ...
随机推荐
- spark复习笔记(4):RDD变换
一.RDD变换 1.返回执行新的rdd的指针,在rdd之间创建依赖关系.每个rdd都有一个计算函数和指向父rdd的指针 Spark是惰性的,因此除非调用某个转换或动作,否则不会执行任何操作,否则将触发 ...
- log4j日志输出格式
%n- 换行 %m - 日志内容 %p - 日志级别(FATAL, ERROR, WARN, INFO, DEBUG or custom) %r - 程序启动到现在的毫秒数 %% - percent ...
- R语言——ggplot2补充知识点
案例 ggplot(head(age_data,10),aes(x=reorder(Country,age_median),y=age_median))+ geom_bar(aes(fill=Coun ...
- Linux性能优化从入门到实战:05 CPU篇:硬中断、软中断
软中断(softirq)会导致CPU 使用率升高 中断是系统用来响应硬件设备请求的一种机制,它会打断进程的正常调度和执行,然后调用内核中的中断处理程序来响应设备的请求.中断其实是一种异步的事件 ...
- Ts 的类
TS 中的公共.私有和受保护的修饰符: 1.public表示公共的,用来指定在创建实例后可以通过实例访问的,也就是类定义的外部可以访问的属性和方法.默认是 public 2.private修饰符表示私 ...
- 1.Linux安装redis
Linux安装redis 操作系统是Centos7 1.下载压缩包 2.解压 3.编译 4.启动redis 5.设置redis.conf和防火墙端口开放,外网可以访问 1.下载压缩包 下载地址:htt ...
- hdu 6127 : Hard challenge (2017 多校第七场 1008)(计算几何)
题目链接 题意:二维平面上有n个点(没有重叠,都不在原点,任意两点连线不过原点),每个点有一个权值,用一条过原点的直线把他们划分成两部分,使两部分的权值和的乘积最大.输出最大的乘积. 极角排序后,将原 ...
- yolo v3 loss=nan, Avg loss=nan的一种原因
我这里是由于数据整理错误导致的,同一标注区域重复2次送入模型,具体如下: 0.798046875 0.5555555555555556 0.04296875 0.03611111111111111 0 ...
- SpringCLoud之搭建Zuul网关集群
1.使用技术 Springboot,SpringCloud,Zuul,Nignx 2.目的 使用Zuul搭建微服务高可用的网关 3.项目创建 3.1 创建注册中心(略) 3.2 创建一个hello-s ...
- Linux内核设计与实现 总结笔记(第八章)下半部和推后执行的工作
上半部分的中断处理有一些局限,包括: 中断处理程序以异步方式执行,并且它有可能打断其他重要代码的执行. 中断会屏蔽其他程序,所以中断处理程序执行的越快越好. 由于中断处理程序往往需要对硬件进行操作,所 ...