如上图所示,java.lang 包中的 Throwable 类是所有异常类的父类,其中包括两大子类,分别是 Error 和 Exception。
-
Error(错误):程序无法处理的错误。表示运行应用程序中较严重的问题,绝大多数是程序运行时不允许出现的状况,同时,这些错误是不可查的,因为它们在应用程序的控制和处理能力之外。
-
Exception(异常):异常和错误的区别在于异常能被程序本身处理,而错误是无法处理的。
-
try 块:用于捕获异常。其后可接零个或多个 catch 块,如果没有 catch 块,则必须跟一个 finally 块;
-
catch 块:用于处理 try 捕获到的异常。
-
finally 块:无论是否捕获或处理异常,finally 块里的语句都会被执行,当在 catch 块中遇到 return 语句时,finally 语句块将在方法返回之前被执行。不过当出现以下四种特殊情况时,finally 块不会被执行:
-
在 finally 语句块第一行发生了异常。
-
在前面的代码中使用了 System.exit(int) 来已退出程序,若该语句在异常语句之后,finally 会执行;
-
程序所在的线程死亡;
-
关闭了 CPU。
注意:当 try 语句和 finally 语句中都有 return 语句时,在方法返回之前,finally 语句的内容将被执行,并且 finally 语句的返回值将会覆盖原始的返回值。如下:
public static int f(int value) {
try {
return value * value;
} finally {
if (value == 2) {
return 0;
}
}
}
// 如果调用 f(2),输出的结果为 0。
=============================================================================
在运行期间,通过 Java 的反射机制,对于任何一个类,都能够知道这个类的属性和方法;对于任何一个对象,都能够调用这个对象的属性和方法。Java 的反射机制可以让用户动态地获取类的信息以及动态调用对象的功能。
反射的原理就是利用 Java 虚拟机通过类的字节码文件反向获取该类或者对象中的属性和方法。
-
优点: 动态加载类,提高代码灵活度;
-
**缺点:**因为反射相当于一系列解释操作,因此性能比直接的 java 代码要慢;使用反射会模糊程序内部逻辑。
反射是框架设计的灵魂。
比如在 MyBatis 中,当使用 标签逐⼀定义列名和对象属性名之间的映射关系后,MyBatis 就可以通过反射来创建对象,同时利用反射给对象的属性逐⼀赋值并返回,那些找不到映射关系的属性,是⽆法完成赋值的;
又比如在 Spring 的 IoC,就是通过解析 XML 文件,获取到 id 属性和 class 属性里面的内容,然后利用反射原理获取到配置里面类的实例对象,并存入到 Spring 的 bean 容器中。
1 反射的应用场景
-
Spring 的 IoC 和 AOP 的实现都和反射有关;
-
代码的逆向编译;
2 反射的实现方式
Class 类是基于反射机制的,Class 由 final 修饰,一个 Class 类的实例表示这个类的类型信息。
-
通过
Class c1 = 类名.class
-
通过
Class c2 = 对象名.getClass()
-
通过
Class c3 = Class.forName(类的全名的字符串)
=============================================================================
-
序列化:将对象写入到 IO 流中;
-
反序列化:从 IO 流中恢复对象;
-
意义:序列化机制允许将实现序列