标签:check NPU 而不是 ack xxx ror print exception etl
ArrayIndexOutOfBoundsException 数组越界异常
ClassCastException 类型转换异常
ClassNotFoundException 类找不到异常
NullPointerException 空指针异常 NPE
…
异常:
在程序运行中/生活过程中,所发生的不正常的/不符合预期的情况(意外),这就是异常,它会导致程序的中断或者过程的结束。
try : 尝试
catch:捉 捕获 抓
finally:最终的
throw:抛 扔
throws:抛 扔 / 计算机释义:声明
try-catch系列
try{
// 可能会出现异常问题的代码段
}catch(能够捕获的异常类型 名){
// 对异常进行处理的代码段
}
添加了异常处理机制之后,程序运行的情况:
未出现异常
正常执行try中的和try-catch后的代码,不会执行catch中的代码。
出现[对应]的异常
在执行try中的代码时,如果出现异常,try中的代码不再往下执行,JVM会立刻创建对应的异常对象,然后将此对象传递给catch块中的异常类型形参,进入catch块对异常进行处理,处理完后继续执行后续代码。
出现[不对应]的异常
在执行try中的代码时,如果出现异常,try中的代码不再往下执行,JVM会立刻创建对应的异常对象,然后将此对象传递给catch块中的异常类型形参,【但如果catch的形参不匹配,则无法传入,也就无法进行异常处理,程序中断(和未添加异常处理一样的效果)】
try{
// 可能出现异常的代码段
}catch(异常类型1){
// 对应处理代码
}catch(异常类型2){
// 对应处理代码
}catch(){
.....
}
类似于多重if,只要有一个异常类型满足,剩下的异常类型捕获不会执行!
public class Demo1 {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
try {
System.out.print("请输入被除数:");
int num1 = input.nextInt();
System.out.print("请输入除数:");
int num2 = input.nextInt();
// 计算结果
int result = num1 / num2;
System.out.println(num1+"/"+num2+" 的结果为:"+result);
} catch (InputMismatchException e) {
System.out.println("输入格式不正确!必须是整数!");
e.printStackTrace();
} catch (ArithmeticException e) {
System.out.println("除数不能为0!");
e.printStackTrace();
}catch (Exception e) { // 异常体系中最大的类型 多态
System.out.println("出现了未知错误!");
}
System.out.println("感谢您的使用!程序结束!");
}
}
它的应用场景:需要对不同的异常进行不同的处理操作时,需要多重catch,但在很多场景下,为了省事,会直接捕获一个Exception父类。
finally中的代码,无论程序是否出现异常都会正常执行。
当finally和return同时出现时,会先执行finally中的代码然后执行return。
finally除断电等物理情况外的唯一不执行时机:System.exit(0); // 退出虚拟机
finally,final,finalize的区别。(面试题)
throw 接异常对象 抛出自定义的或者更全面的异常信息对象。
throws 接异常类型 标注在方法声明上的,用来声明此方法可能出现的异常类型。
public class 自定义异常类型 extends Exception{
// 编写带参构造
// 编写无参构造
}
Throwable
Error(程序无法修复 必须人工修改) Exception(可通过代码/程序进行动态修复的)
? Checked异常(受检异常:编写出来 就提示你进行解决) Runtime异常(运行时异常:代码执行过程中出现的异常,有些时候不需要修复, InputMismatchException ArthimaticException ArrayIndexOutOfBoundsException …都属于运行时异常)
QQ空间:《日志/日记 谈一场轰轰烈烈的恋爱 …》
程序中的日志:记录程序运行过程中的状态信息(一般会记录重要信息),也是解决问题的一种手段(推荐在大型项目中使用日志进行debug而不是工具debug)。
xxx.log
导包 将jar包变成"小奶瓶"
配置log4j (配置输出日志的格式和位置等) 通过log4j.properties 放在src目录下
使用API 进行日志记录
Logger logger = Logger.getLogger(字节码对象:类名.class);
logger.info();
logger.error();
logger.debug();
标签:check NPU 而不是 ack xxx ror print exception etl
原文地址:https://www.cnblogs.com/zhang321/p/13192595.html