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
使用API 进行日志记录
Logger logger = Logger.getLogger(字节码对象:类名.class);