Java 异常类层次结构图 Java 中,所有的异常都有一个共同的祖先 java.lang 包中的 ThrowableThrowable: 有两个重

要的子类:Exception(异常) Error(错误) ,二者都是 Java 异常处理的重要子类,各自都包含大

量子类。

Error(错误):是程序无法处理的错误,表示运行应用程序中较严重问题。大多数错误与代码编写者执

行的操作无关,而表示代码运行时 JVMJava 虚拟机)出现的问题。例如,Java 虚拟机运行错误

Virtual MachineError),当 JVM 不再有继续执行操作所需的内存资源时,将出现

OutOfMemoryError。这些异常发生时,Java 虚拟机(JVM)一般会选择线程终止。

这些错误表示故障发生于虚拟机自身、或者发生在虚拟机试图执行应用时,如Java 虚拟机运行错误

Virtual MachineError)、类定义错误(NoClassDefFoundError)等。这些错误是不可查的,因为它

们在应用程序的控制和处理能力之 外,而且绝大多数是程序运行时不允许出现的状况。对于设计合理的

应用程序来说,即使确实发生了错误,本质上也不应该试图去处理它所引起的异常状况。在 Java 中,错

误通过 Error 的子类描述。

Exception(异常):是程序本身可以处理的异常Exception 类有一个重要的子类

RuntimeExceptionRuntimeException 异常由 Java 虚拟机抛出。

NullPointerException(要访问的变量没有引用任何对象时,抛出该异常)、

ArithmeticException(算术运算异常,一个整数除以 0 时,抛出该异常)和

ArrayIndexOutOfBoundsException (下标越界异常)。

注意:异常和错误的区别:异常能被程序本身可以处理,错误是无法处理。

Throwable 类常用方法

public string getMessage():返回异常发生时的详细信息

public string toString():返回异常发生时的简要描述

public string getLocalizedMessage():返回异常对象的本地化信息。使用 Throwable 的子类覆盖

这个方法,可以声称本地化信息。如果子类没有覆盖该方法,则该方法返回的信息与 getMessage()

返回的结果相同

public void printStackTrace():在控制台上打印 Throwable 对象封装的异常信息异常处理总结

• try 块:用于捕获异常。其后可接零个或多个 catch 块,如果没有 catch

块,则必须跟一个 finally 块。

• catch 块:用于处理 try 捕获到的异常。

• finally 块:无论是否捕获或处理异常,finally 块里的语句都会被执行。

当在 try 块或 catch 块中遇到 return 语句时,finally 语句块将在方法返回之前被执行。在以下 4 种特殊

情况下,finally 块不会被执行:

1.  finally 语句块中发生了异常。

2. 在前面的代码中用了 System.exit()退出程序。

3. 程序所在的线程死亡。

4. 关闭 CPU

Java 序列化中如果有些字段不想进行序列化 怎么办

对于不想进行序列化的变量,使用 transient 关键字修饰。

transient 关键字的作用是:阻止实例中那些用此关键字修饰的的变量序列化;当对象被反序列化时,被

transient 修饰的变量值不会被持久化和恢复。 transient 只能修饰变量,不能修饰类和方法。

获取用键盘输入常用的的两种方法

方法 1:通过 Scanner

Scanner input = new Scanner(System.in);

String s = input.nextLine(); input.close();

方法 2:通过 BufferedReader

BufferedReader input = new BufferedReader(new InputStreamReader(System.in));

String s = input.readLine();

接口继承关系和实现

集合类存放于 Java.util 包中,主要有 3 种:set(集)、list(列表包含 Queue)和 map(映射)

1. CollectionCollection 是集合 ListSetQueue 的最基本的接口。

2. Iterator:迭代器,可以通过迭代器遍历集合中的数据

3. Map:是映射表的基础接口List

Java  List 是非常常用的数据类型。List 是有序的 CollectionJava List 一共三个实现类:分别是

ArrayListVector  LinkedList

ArrayList(数组)

ArrayList 是最常用的 List 实现类,内部是通过数组实现的,它允许对元素进行快速随机访问。数组的缺

点是每个元素之间不能有间隔,当数组大小不满足时需要增加存储能力,就要将已经有数组的数据复制

到新的存储空间中。当从 ArrayList 的中间位置插入或者删除元素时,需要对数组进行复制、移动、代

价比较高。因此,它适合随机查找和遍历,不适合插入和删除。

Vector(数组实现、线程同步)

Vector  ArrayList 一样,也是通过数组实现的,不同的是它支持线程的同步,即某一时刻只有一

个线程能够写 Vector,避免多线程同时写而引起的不一致性,但实现同步需要很高的花费,因此,访问

它比访问 ArrayList 慢。

LinkList(链表)

LinkedList 是用链表结构存储数据的,很适合数据的动态插入和删除,随机访问和遍历速度比较慢。另

外,他还提供了 List 接口中没有定义的方法,专门用于操作表头和表尾元素,可以当作堆栈、队列和双

向队列使用。

05-04 21:55