总结了一下 JAVA 中常见的几种 RuntimeException,大约有如下几种: 1.NullPointerException - 空指针引用异常 2.ClassCastException - 类型强制转换异常。 3.IllegalArgumentException - 传递非法参数异常。4.ArithmeticException - 算术运算异常 5.ArrayStoreException - 向数组中存放与声明类型不兼容对象异常 6.IndexOutOfBoundsException - 下标越界异常 7.NegativeArraySizeException - 创建一个大小为负数的数组错误异常 8.NumberFormatException - 数字格式异常 9.SecurityException - 安全异常 10.UnsupportedOperationException - 不支持的操作异常 如下:RuntimeException 是开发中最容易遇到的,下面列举一下常见的 RuntimeException: 1、NullPointerException:见的最多了,其实很简单,一般都是在 null 对象上调用方法了。 String s=null; boolean eq=s.equals(""); // NullPointerException 这里你看的非常明白了,为什么一到程序中就晕呢? public int getNumber(String str){ if(str.equals("A")) return 1; else if(str.equals("B")) return 2; } 这个方法就有可能抛出 NullPointerException,我建议你主动抛出异常,因为代码一多,你可 能又晕了。 public int getNumber(String str){ if(str==null) throw new NullPointerException("参数不能为空"); //你是否觉得明白多了 if(str.equals("A")) return 1; else if(str.equals("B")) return 2; } 2、NumberFormatException:继承 IllegalArgumentException,字符串转换为数字时出现。比 如 int i= Integer.parseInt("ab3"); 3、ArrayIndexOutOfBoundsException:数组越界。比如 int[] a=new int[3]; int b=a[3]; 4、StringIndexOutOfBoundsException:字符串越界。比如 String s="hello"; char c=s.chatAt(6); 5、ClassCastException:类型转换错误。比如 Object obj=new Object(); String s=(String)obj; 6、UnsupportedOperationException:该操作不被支持。如果我们希望不支持这个方法,可以抛 出这个异常。 既然不支持还要这个干吗?有可能子类中不想支持父类中有的方法, 可以直接 抛出这个异常。 7、ArithmeticException:算术错误,典型的就是 0 作为除数的时候。 8、IllegalArgumentException:非法参数,在把字符串转换成数字的时候经常出现的一个异 常,我们可以在自己的程序中好好利用这个异常。 我们可创建一个控制器,令其捕获所有类型的违例。具体的做法是捕获基础类违例类型 Exception(也存在其他类型的基础违例,但 Exception 是适用于几乎所有编程活动的基础) 。 如下所示: catch(Exception e) { System.out.println("caught an exception"); } 这段代码能捕获任何违例, 所以在实际使用时最好将其置于控制器
列表的末尾, 防止跟 随在后面的任何特殊违例控制器失效。
对于程序员
常用的所有违例类来说,由于 Exception 类是它们的基础,所以我们不会获 得关于违例太多的信息,但可调用来自
它的基础类 Throwable 的方法: String getMessage() 获得详细的消息。 String toString() 返回对 Throwable 的一段简要说明,其中包括详细的消息(如果有的话) 。 void printStackTrace() void printStackTrace(PrintStream) 打印出 Throwable 和 Throwable 的调用堆栈路径。调用堆栈显示出将我们带到违例发生 地点的方法调用的顺序。 第一个版本会打印出标准错误,第二个则打印出我们的选择流程。若在 Windows 下工 作, 就不能重定向标准错误。 因此, 我们一般愿意使用第二个版本, 并将结果送给 System.out; 这样一来,输出就可重定向到我们希望的任何路径。 除此以外,我们还可从 Throwable 的基础类 Object(所有对象的基础类型)获得另外一 些方法。对于违例控制来说,其中一个可能有用的是 getClass(