Java 中的异常处理1

Java 异常类层次结构图
 
 
Java 中,所有的异常都有一个共同的祖先 java.lang 包中的 Throwable Throwable: 有两个重要的子类: Exception (异常) Error (错 误) ,二者都是 Java 异常处理的重要子类,各自都包含大量子类。
 
Error (错误) : 是程序无法处理的错误,表示运行应用程序中较严重问题。大多数错误与代码编写者执行的操作无关,而表示代码运行时 JVM Java 虚拟机)出现的问题。例如, Java 虚拟机运行错误( Virtual MachineError),当 JVM 不再有继续执行操作所需的内存资源时,将出现 OutOfMemoryError。这些异常发生时, Java 虚拟机(JVM)一般会选择线程终止。这些错误表示故障发生于虚拟机自身、或者发生在虚拟机试图执行应用时,如 Java 虚拟机运行错误( Virtual MachineError )、类定义错误
NoClassDefFoundError)等。这些错误是不可查的,因为它们在应用程序的控制和处理能力之 外,而且绝大多数是程序运行时不允许出现的状况。对于设计合理的应用程序来说,即使确实发生了错误,本质上也不应该试图去处理它所引起的异常状况。在 Java 中,错误通过 Error 的子类描述。
 
Exception (异常) : 是程序本身可以处理的异常 Exception 类有一个重要的子类 RuntimeException RuntimeException 异常由 Java 虚拟机抛出。 NullPointerException (要访问的变量没有引用任何对象时,抛出该异常)、 ArithmeticException (算术运算异常,一个整数除以 0 时,抛出该异常)和 ArrayIndexOutOfBoundsException (下标越界异常)。
 
注意:异常和错误的区别:异常能被程序本身可以处理,错误是无法处理。
必须捕获的异常:
  • Exception及其子类,但不包括RuntimeException及其子类
  • 统成为CheckedException

不需要捕获的异常:

  • ​​​​​​​Error及其子类
  • RuntimeException及其子类
 
 
Throwable 类常用方法
  • public string getMessage():返回异常发生时的详细信息
  • public string toString():返回异常发生时的简要描述
  • public string getLocalizedMessage():返回异常对象的本地化信息。使Throwable 的子类覆盖这个方法,可以声称本地化信息。如果子类没有覆盖该方法,则该方法返回的信息与 getMessage()返回的结果相同
  • public void printStackTrace():在控制台上打印 Throwable 对象封装的异常信息
异常处理总结
  • try 块:可能发生异常的语句放到try{...}用于捕获异常。其后可接零个或多个 catch 块,如果没有 catch 块,则必须跟一个 finally 块。
  • catch 块:用于处理 try 捕获到的异常,catch捕获顺序很重要,捕获第一个异常就不会继续往下匹配了,所以要把子类异常写在前面。
  • finally 块:无论是否捕获或处理异常,finally 块里的语句都会被执行。
public static void main(String [] args){
    try{
        process1();
        process2();
        process3();
    }catch(IOException e){
        System.out.println(e);
    }
}
String有个getBytes方法可能抛出UnsupportEncodingException异常:
static byte[] toGBK(String s){
    try{
        return s.getBytes("GBK");
    }catch(UnsupportedEncodingException e){
        System.out.println(e);
    }
}

但是我们可以用throws抛出异常仍需在上层捕获,推迟捕获异常:

static byte[] toGBK(String s)
throws UnsupportedEncodingExcepion{
    return s.getBytes("GBK");
}

public static void main(String[] args){
    try {
        byte[] data = toGBK("wensong");
    }catch (UnsupportedEncodingException e){
        System.out.println(e);
    }
}

由于main方法是Java程序调用的第一个方法,所以是最后捕获Exception的机会,如果异常被抛出,在main方法中没有被捕获到,JVM就会退出并报错。

static byte[] toGBK(String s)
throws UnsupportedEncodingException{
    return s.getByte("GBK");
}

public static void main(Strig [] args)
throws Exception{
    byte[] data = toGBK("wensong");
}

实例:

package wensong.com;
import java.io.UnsupportedEncodingException;
public class TestException {
    public static void main(String[] args) {
        test("UTF-8");
        test("hahaha");
    }
    static void test(String encoding){
        System.out.println("test encoding: "+encoding+"......");
        try{
            "wensong".getBytes(encoding);
            System.out.println("OK");
        }catch(UnsupportedEncodingException e){
            System.out.println("failed...");
            System.out.println(e);
        }
    }
}

执行结果:

测试正常的UTF-8编码没有异常,继续执行打印“ok”,然后测试非法编码“hahaha”时抛出异常,然后后面的“ok”有没有执行,catch捕获异常之后处理异常

test encoding: UTF-8......
OK
test encoding: hahaha......
failed...
java.io.UnsupportedEncodingException: hahaha

相同异常处理可以用 | 来合并捕获异常,做后执行finally语句:

package wensong.com;

public class TestOrFinally {
    public static void main(String [] args){
        process("0");
    }
    static void process(String s){
        try{
            int n = Integer.parseInt(s);
            int m = 100/n;
        }catch(NumberFormatException | ArithmeticException e){
            System.out.println(e);
            System.out.println("Bad input!");
        }finally{
            System.out.println("end!");

        }
    }
}

运行结果:

java.lang.ArithmeticException: / by zero
Bad input!
end!

 

 
当在 try 块或 catch 块中遇到 return 语句时, finally 语句块将在方法返回之前被执行
 
在以下 4 种特殊情况下, finally 块不会被执行:
  1. finally 语句块中发生了异常。
  2. 在前面的代码中用了 System.exit() 退出程序。
  3. 程序所在的线程死亡。
  4. 关闭 CPU
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值