“违例”(Exception)这个词表达的是一种“例外”情况,亦即正常情况之外的一种“异常”。在问题发生的时候,我们可能不知具体该如何解决,但肯定知道已不能不顾一切地继续下去。此时,必须坚决地停下来,并由某人、某地指出发生了什么事情,以及该采取何种对策。但为了真正解决问题,当地可能并没有足够多的信息。因此,我们需要将其移交给更级的负责人,令其作出正确的决定(类似一个命令链)。
其实就是发生一些异常的时候,给出java相应的指示:现在程序发生异常了,我该怎么做,你要是不告诉我的话,我就停止运行了!
- 基本异常的产生:
- 手动抛出:当满足一定的条件时,程序员认为这个时候即可认为发生了“异常”,这个时候就可以手动抛出异常对象
@Test
public void test2() throws Exception{
if(true){
throw new Exception();
}
} 程序自己抛出:当程序认为不满足合法要求的时候,Java本身也会自动抛出相应的异常:
@Test
public void test3() {
int i = 1 / 0;
/*
* java.lang.ArithmeticException: / by zero at
* Mytest.Test01.test3(Test01.java:68) at
* sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at....
*
*/
}
- 手动抛出:当满足一定的条件时,程序员认为这个时候即可认为发生了“异常”,这个时候就可以手动抛出异常对象
异常的捕获try{}catch(){}
往往发生异常的时候我们都需要受益人采取一定的措施,那么如何我们怎么知道什么时候发生异常了,发生了什么样的异常了呢?@Test
public void test4() {
try {
/* 正常的代码放在try{}中 */
int i = 1 / 0;// 肯定会发生ArithmeticException的异常
} catch (ArithmeticException e/*当发生ArithmeticException异常应该做什么*/) {
System.out.println("ArithmeticException");//ArithmeticException
} catch (NullPointerException e/*当发生NullPointerException异常应该做什么*/) {
System.out.println("NullPointerException");
}catch(Exception e/*当不知道会发生什么异常的时候,可以用Exception来捕获,注意cacth的顺序是:范围大的放下面*/){
System.out.println("Exception");
}
}值得注意的是:当其中一个对应的catch捕获到异常以后,别的catch是不会再运行的了
- throw(抛出)与throws(声明)
当你的方法中,throw出了一个异常,你又不想做出对应的解决方案:即,try...catch..那么别人使用你的方法只有两种选择:一,我来处理。二,我也不处理,我也只是告诉别人我这方法中有哪些异常;所以你的方法中必须要告诉别人我这个方法中throw出了哪些异常,java违例规范中就强制我们当方法中的发生的异常(运行时异常除外),你不处理的时候,你必须指出方法中的哪些异常,这个时候就是throws的指明的时候了:@Test
public void test5() throws IllegalClassFormatException {
if(1<2){
throw new RuntimeException();//运行时异常,不用处理
}
if(2>3){
throw new IllegalClassFormatException();//不进行处理时,必须通过throws声明出
}
if(3>4){
try {
throw new Exception();//进行try{}catch(){}处理
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
} - 自定义异常:extends Exception
class MyException extends Exception{}
- 继承时,覆盖的方法中不能抛出比父类多的异常:
public class Parent {
public void a() throw AException {
}
}
public class Child extends Parent {
public void a() throw AException, BException {
}
} public class Test {
public void main(String[] args) {
Parent p = new Child();
try {
p.a();//这里在调用者就不知道抛出BException了!这样就会导致一些问题
} catch(AException e) {
doSomething();
}
}
} - finally{}
当有些逻辑不管程序有没有发生异常,都必须要被执行的话可以放在finally中。@Test
public void test01() {
try{
int i=1/0;
System.out.println("this is a very important");
}catch(Exception e){
System.out.println("****************");//当代码执行到1/0时,会发生异常,程序会到catch{}中,执行******故important不会执行
}
}@Test
public void test01() {
try{
int i=1/0; }catch(Exception e){
System.out.println("****************");
return;
}finally{
System.out.println("this is a very important");
//即使当程序执行到1/0后,程序抓到异常,执行catch块并且return,finally还是会执行
}
}注意:finally是在return前执行的,执行完以后return;
那么什么情况下finally是不会被执行的呢?
@Test
public void test01() {
try{
int i=1/0; }catch(Exception e){
System.out.println("****************");
System.exit(-1);//终止java虚拟机的运行
}finally{
System.out.println("this is a very important");
//即使当程序执行到1/0后,程序抓到异常,执行catch块并且return,finally还是会执行
}
} - java异常体系中的缺陷
@Test
public void test02 () throws Exception{
try {
int i=1/0;
} finally {
throw new Exception("我是exception");
}
}分析可知,按理说,上面的程序应该先抛出ArithmeticException,再抛出Exception,可结果:
ArithmeticException没有了!!这在thinking in java中已经提出,但到1.8版本并没解决