RuntimeException运行时出现的各种异常
派生于RuntimeException的异常,如被 0 除、数组下标越界、空指针等,其产生比较频繁,处理麻烦,如果显式的声明或捕获将会对程序可读性和运行效率影响很大。 因此由系统自动检测并将它们交给缺省的异常处理程序(用户可不必对其处理)
这类异常通常是由编程错误导致的,所以在编写程序时,并不要求必须使用异常处理机制来处理这类异常,经常需要通过增加“逻辑处理来避免这些异常”。
一.运算条件异常(ArithmeticException)
试图除以0
public class TextException{
public static void main(String[] args){
//运算条件异常
int a = 0;
int b = 1;
System.out.println(b/a);
}
}
此处0不能做除数,会报运算条件异常:
修改 :增加if进行条件判断
public class TestException {
public static void main(String[] args) {
int a = 0;
int b = 1;
if (a != 0) {
System.out.println(b / a);
}
}
}
二.空指针异常(NullPointerException)
当程序访问一个空对象的成员变量或方法,或者访问一个空数组的成员时会发生空指针异常(NullPointerException)。
public class TestException{
public static void main(String[] args){
//空指针异常:一个对象为空,调用了该对象的属性和方法
String str = null;
str.length();
}
}
空指针异常是指对象为空,而你调用了它的属性或方法,此时会报空指针异常:
修改 : 解决空指针异常,通常是增加非空判断
public class TestException {
public static void main(String[] args){
String str = null;
if (str != null) {
str.length();
}
}
}
三.强制类型转换异常(ClassCastException)
在引用数据类型转换时,有可能发生类型转换异常(ClassCastException)。
public class TestException {
public static void main(String[] args) {
//强制类型转换异常
Animal d = new Dog();
Cat c = (Cat)d;
}
}
class Animal{
}
class Cat extends Animal{
}
class Dog extends Animal{
}
强制将Dog()类型的d转换为Cat()类型的c会发生错误,两者不同类。此时会报强制类型转换异常:
修改:加入instanceof语句进行对象和类所属关系的判断
public class TestException {
public static void main(String[] args) {
Animal d = new Dog();
if (d instanceof Cat){
Cat c = (Cat)d;
}
}
}
class Animal{
}
class Cat extends Animal{
}
class Dog extends Animal{
}
四.数组越界异常(ArrayIndexOutOfBoundsException)
当程序访问一个数组的某个元素时,如果这个元素的索引超出了0~数组长度-1这个范围,则会出现数组下标越界异常(ArrayIndexOutOfBoundsException)。
public class TestException {
public static void main(String[] args) {
//数组越界异常
int[] num =new int[5];
int i = 5;
if(i<=num.length-1)
System.out.println(num[i]);
}
}
数组下标与长度混淆,造成数组越界。此时会报数组越界异常:
修改: 解决数组索引越界异常的方式,增加关于边界的判断
public class TestException {
public static void main(String[] args) {
int[] num =new int[5];
int i = 5;
if(i<=num.length-1)
System.out.println(num[i]);
}
}
注意事项
1. 在方法抛出异常之后,运行时系统将转为寻找合适的异常处理器(exception handler)。潜在的异常处理器是异常发生时依次存留在调用栈中的方法的集合。当异常处理器所能处理的异常类型与方法抛出的异常类型相符时,即为合适的异常处理器。
2. 运行时系统从发生异常的方法开始,依次回查调用栈中的方法,直至找到含有合适异常处理器的方法并执行。当运行时系统遍历调用栈而未找到合适的异常处理器,则运行时系统终止。同时,意味着Java程序的终止。