1、java中所有的错误都会被打包为对象,JVM会尝试执行try区块中的程序代码,如果发生错误,执行流程会跳离错误发生点,然后比较catch括号中声明的异常类型,是否符合被抛出的错误对象类型,如果是的话,就执行catch区块中的程序代码。

2、错误对象都继承自java.lang.Throwable类,Throwable定义了取得错误信息、堆栈追踪等方法,它有两个子类:java.lang.Error与java.lang.Exception。

3、Error与其子类实例代表严重系统错误,Error对象抛出时,基本上不用处理,任其传播至JVM为止,或者是最多留下日志信息。

4、通常程序中会使用try、catch加以处理的错误,都是Exception或其子类实例,所以通常称错误处理为异常处理,对于某些异常,可以try、catch语法尝试捕捉将应用程序恢复至可执行状态。

5、如果某个方法声明会抛出Throwable、Exception或子类实例,但又不属于java.lang.RuntimeException或其子类实例,就必须明确使用try、catch语法加以处理,或者用throws声明这个方法会抛出异常,否则会编译失败。

6、Throwable、Exception或其子对象,但非属于RuntimeException或其子对象,称为受检异常。

7、属于RuntimeException衍生出来的类实例,通常是事先无法预测错误是否发生的执行时期异常,编译程序不会强迫一定得在语法上加以处理,称为非受检异常。

8、如果父类异常对象在子类异常对象前被捕捉,则catch子类异常对象的区块将永远不会被执行,编译程序会检查出这个错误。

9、从JDK7开始,可以使用多重捕捉语法,不过仍得注意异常的继承,catch括号中,左边的异常不能是右边异常的父类,否则会发生编译错误。

10、操作对象的过程中如果会抛出受检异常,但目前环境信息不足以处理异常,所以无法使用try、catch处理时,可由方法的客户端依据当时调用的环境信息进行处理。为了告诉编译程序这个事实,必须使用throws声明此方法会抛出的异常类型或父类型,编译程序才会允许通过编译。

11、如果是非受检异常,原本就可以自行选择是否处理异常,因此不使用try、catch处理时也不用特别在方法上使用throws声明,不处理非受检异常时,异常会自动往外传播。

12、在catch区块中进行完部分错误处理之后,可以使用throw(注意不是throws)将异常再抛出。

13、在JDK7中,编译程序对于重新抛出的异常类型可以更精准判断。

14、若想得知异常发生的根源,以及多重方法调用下异常的堆栈传播,可以利用异常对象自动收集的堆栈追踪来取得相关信息,例如调用异常对象的printStackTrace()、getStackTrace()等方法。

15、要善用堆栈追踪,前提是程序代码中不可有私吞异常的行为、对异常做了不适当的处理,或显示了不正确的信息。

16、在使用throw重抛异常时,异常的追踪堆栈起点,仍是异常的发生根源,而不是重抛异常的地方。如果想要让异常堆栈起点为重抛异常的地方,可以使用fillInStackTrace(),这个方法会重新装填异常堆栈,将起点设为重抛异常的地方,并返回Throwable对象。

17、无论try区块中有无发生异常,若撰写有finally区块,则finally区块一定会被执行。如果程序撰写的流程中先return了,而且也有finally区块,finally区块会先执行完后,再将值返回。

18、在JDK7之后,新增了尝试关闭资源(try-with-resources)语法,想要尝试自动关闭资源的对象,是撰写在try之后的括号中。

19、若一个异常被catch后的处理过程引发另一个异常,通常会抛出第一个异常作为响应,addSupperssed()方法是JDK7在java.lang.Throwable中新增的方法,可将第二个异常记录在第一个异常之中,JDK7中与之对应的是getSupperssed()方法,可返回Throwable[],代表先前被addSupperssed()记录的各个异常对象。

20、JDK7的尝试关闭资源语法可套用的对象,必须操作java.lang.AutoCloseable接口,这是JDK7新增的接口。尝试关闭资源语法也可以同时关闭两个以上的对象资源,只要中间以分号分隔。在try的括号中,越后面撰写的对象资源会越早被关闭。

课后练习选择题:

1、public class Main{

public static void main(String[] args){

try{

int number = Integer.parseInt(args[0]);

System.out.println(number++);

}catch(NumberFormatException ex){

System.out.println(“必须输入数字”);

}

}

}

执行时若没有指定命令行自变量,以下描述正确的是:显示ArrayIndexOutOfBoundException堆栈追踪。

2、Object[] objs = {“java”,”7”};

Integer number = (Integer) objs[1];

System.out.println(number);

以下描述正确的是:显示ClassCastException堆栈追踪

3、public class Main{

public static void main(String[] args){

try{

int number = Integer.parseInt(args[0]);

System.out.println(number++);

}catch(NumberFormatException ex){

System.out.println(“必须输入数字”);

}

}

}

执行时若指定命令行自变量one,以下描述正确的是: 显示的必须输入数字。

4、public class FileUtil{

public static String readFile(String name) throws                {
                   FileInputStream input = new FileInputStream(name);
                   return null;
           }

}

方法名的throws关键字后要加FileNotFoundException ,声明该方法需要抛出找不到文件的异常。

5、public static String readFile(String name) {
        try {
            FileInputStream input = new FileInputStream(name);
        } catch (              e) {
            e.printStackTrace();
        }
        return null;
    }

catch括号中描述正确的是:填入Throwable或者FileNotFoundException可以通过编译。

6、public class ExtendsDemo1 extends Resourse{
    @Override
    void doService() throws              {}
    
    public static void main(String[] args){

}   
}

class Resourse{
    void doService() throws IOException{}
}

红色区域填入Error、IOException、FileNotFoundException选项都可以通过编译。

7、public class Main{

public static void main(String[] args){

try{

int number = Integer.parseInt(args[0]);

System.out.println(number++);

}catch(ArrayIndexOutOfBouondException  | NumberFormatException ex){

System.out.println(“必须输入数字”);

}

}

}

以下描述正确的是:显示”必须输入数字“。

8、public static void main(String[] args){

try{

int number = Integer.parseInt(args[0]);

System.out.println(number++);

}catch(RuntimeException  | NumberFormatException ex){

System.out.println("必须输入数字");

}

}

以下描述正确的是:编译错误。

注:因为左侧Runtime是右侧NumberFormatException的父类。

9、public static String readFile(String name){
            try( FileInputStream input = new FileInputStream(name)){
               
            }
         }

以下描述正确的是:编译失败、

10、try(ResourceSome some = new  ResourceSome();

RsourceOther other = new ResouceOther()

以下描述正确的是:执行完try后先会关闭ResouceOther。

《java JDK7 学习笔记》之异常处理的更多相关文章

  1. 《java JDK7 学习笔记》之继承与多态

    1.面向对象中,子类继承父类,避免重复的行为定义,不过并非为了避免重复定义行为就使用继承.应该正确判断使用继承的时机及继承之后灵活的运用多态,才是学习继承时的重点. 2.程序代码重复在程序设计上,就是 ...

  2. 《java jdk7学习笔记》之java三大平台

    Sun公司在2006年底,就将三大平台正名为java SE.java EE和java ME.也有很多人习惯用J2SE.J2EE和J2ME. 1.java SE java SE(标准版)是各应用平台的基 ...

  3. 《java JDK7 学习笔记》之Collection

    一.使用Collection 收集对象 1.认识Collection架构 Java SE提供了满足各种需求的API,在使用这些API前,建议先了解其继承与接口操作架构,才能了解何时使用哪个类,以及类之 ...

  4. 《java JDK7 学习笔记》之接口与多态

    1.对于"定义行为"也就是接口,可以使用interface关键字定义,接口中的方法不能操作,直接标示为abstract,而且一定是public修饰的. 类要操作接口,必须使用imp ...

  5. 《java JDK7 学习笔记》之对象封装

    1.构造函数实现对象初始化流程的封装.方法封装了操作对象的流程.java中还可以使用private封装对象私有数据成员.封装的目的主要就是隐藏对象细节,将对象当做黑箱子进行操作. 2.在java命名规 ...

  6. 《java JDK7 学习笔记》之类和对象

    1.在java中,要产生对象必须先定义类,类是对象的设计图,对象是类的实例.类定义时使用class关键词,建立实例对象要使用new关键词.以类名声明的变量,称为参考名称.参考变量或直接叫参考. 2.想 ...

  7. 《Java JDK7 学习笔记》课后练习题1

    1.()组织负责监督审查Java相关技术规格的演进. A. JCP B. Apache C. EU D. W3C 2.Java技术规格必须以()正式文件提交审查. A. RFC B. JSR C. I ...

  8. 《Java JDK7 学习笔记》课后练习题2

    1.如果在hello.java中撰写以下的程序代码: public class Hello {     public static dmain(String[]args) {          Sys ...

  9. 《java JDK7学习笔记》之跨平台与路径设置

    Platforms表示Solaris.Linux.Windows各种操作系统平台,在这些平台上架构了java Virtaul Machine,简称JVM,Java虚拟机. Java虚拟机可以让java ...

随机推荐

  1. Oracle数据块损坏篇之10231内部事件

    实验:某个分区数据块损坏,不完全恢复此分区表数据 背景:数据库没有有效备份,某个分区中有数据块损坏. 要求:最大限度恢复此分区数据. 环境:RHEL 6.4 + Oracle 11.2.0.4 1. ...

  2. (六)WebGIS中地图瓦片在Canvas上的拼接显示原理

    文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/. 1.前言 在之前的五个章节中,我们在第一章节里介绍了WebGIS的基本 ...

  3. 【原创】轻量级移动设备即时通讯技术MobileIMSDK的常见问题解答

    申明:MobileIMSDK 目前为个人原创开源工程且已发布,现整理了一些有关MobileIMSDK的常见的问题,希望对需要的人有用,谢谢.如需与作者交流,见文章底部个人签名处,互相学习. Mobil ...

  4. cookie相关

    参考百度百科: Cookie,有时也用其复数形式Cookies,指某些网站为了辨别用户身份.进行session跟踪而储存在用户本地终端上的数据(通常经过加密).定义于RFC2109和2965都已废弃, ...

  5. Entity Framework Model First下改变数据库脚本的生成方式

    在Entity Framework Model First下, 一个非常常见的需求是改变数据库脚本的生成方式.这个应用场景是指,当用户在Designer上单击鼠标右键,然后选择Generate Dat ...

  6. 淘宝购物车页面 智能搜索框Ajax异步加载数据

    如果有朋友对本篇文章的一些知识点不了解的话,可以先阅读此篇文章.在这篇文章中,我大概介绍了一下构建淘宝购物车页面需要的基础知识. 这篇文章主要探讨的是智能搜索框Ajax异步加载数据.jQuery的社区 ...

  7. MVC学习系列14--Bundling And Minification【捆绑和压缩】--翻译国外大牛的文章

    这个系列是,基础学习系列的最后一部分,这里,我打算翻译一篇国外的技术文章结束这个基础部分的学习:后面打算继续写深入学习MVC系列的文章,之所以要写博客,我个人觉得,做技术的,首先得要懂得分享,说不定你 ...

  8. javascript设计模式实践之模板方法--具有百叶窗切换图片效果的JQuery插件(二)

    在上一篇<javascript设计模式实践之迭代器--具有百叶窗切换图片效果的JQuery插件(一)>里,通过采用迭代器模式完成了各初始化函数的定义和调用. 接下来就要完成各个切换效果的编 ...

  9. Composer根据Name显示与隐藏

    //主要设置 模型的显示与隐藏 private void TransmissionByData_AxSendSelectionChange(string domName, bool isVisible ...

  10. 类型转换及返回json对象的问题

    @ResponseBody @RequestMapping(value="/user/getUserId.do")//method=RequestMethod.POST publi ...