6.3-全栈Java笔记:异常处理方法(上)

异常的处理办法之一  捕获异常

图1 异常处理

上面过程详细解析:

1.try

try语句指定了一段代码,该段代码就是一次捕获并处理的范围。在执行过程中,当任意一条语句产生异常时,就会跳过该段中后面的代码。代码中可能会产生并抛出一种或几种类型的异常对象,它后面的catch语句要分别对这些异常做相应的处理。

一个try语句必须带有至少一个catch语句块或一个finally语句块 。


注意事项

当异常处理的代码执行结束以后,是不会回到try语句去执行尚未执行的代码。

2.catch:

1)每个try语句块可以伴随一个或多个catch语句,用于处理可能产生的不同类型的异常对象。

2)常用方法,这些方法均继承自Throwable类 。

oString ()方法,显示异常的类名和产生异常的原因

getMessage()方法,只显示产生异常的原因,但不显示类名。

printStackTrace()方法,用来跟踪异常事件发生时堆栈的内容。

3)Catch捕获异常时的捕获顺序:

如果异常类之间有继承关系,在顺序安排上需注意。越是顶层的类,越放在下面。再不然就直接把多余的catch省略掉。

3. finally:

1)有些语句,不管是否发生了异常,都必须要执行,那么就可以把这样的语句放到finally语句块中。

2)通常在finally中关闭程序块已打开的资源,比如:文件流、释放数据库连接等。

【示例1】典型代码(先不要敲!!)


package com.bjsxt.four;

import java.io.FileNotFoundException;

import java.io.FileReader;

import java.io.IOException;

public class TestReadFile {

public static void main(String[] args) {

FileReader reader = null;

try{

reader = new FileReader("d:/a.txt");

char c = (char)reader.read();

char c2 = (char)reader.read();

System.out.println(""+c+c2);

}catch(FileNotFoundException e){

e. printStackTrace ();

}catch(IOException e){

e.printStackTrace ();

}finally{

try{

if(reader!=null){

reader.close();

}

}catch (Exception e) {

e. printStackTrace ();

}

}

}

}

异常的处理办法之二  声明异常:throws子句

当Checked Exception产生时,不一定立刻处理它,可以再把异常Throws出去。

在方法中使用try-chatch-finally由这个方法处理异常。在一些情况下,当前方法并不需要处理发生的异常,而是向上传递给调用它的方法处理。

如果一个方法中可能产生某种异常,但是并不能确定如何处理这种异常,则应根据异常规范在方法的首部声明该方法可能抛出的异常。

如果一个方法抛出多个已检查异常,就必须在方法的首部列出所有的异常,之间以逗号隔开。

【示例2】典型代码(先不敲!):

import java.io.FileNotFoundException;

import java.io.FileReader;

import java.io.IOException;

public class Test {

public static void main(String[] args) {

try {

readFile("joke.txt");

catch (FileNotFoundException e) {

System.out.println("所需文件不存在!");

catch (IOException e) {

System.out.println("文件读写错误!");

}

}

public static void readFile(String   fileName) throws FileNotFoundException,IOException {

FileReader in = new FileReader(fileName);

int tem = 0;

try {

tem = in.read();

while (tem != -1) {

System.out.print((char) tem);

tem = in.read();

}

finally {

in.close();

}

}

}

自定义异常

在程序中,可能会遇到任何标准异常类都没有充分的描述清楚的问题,这种情况下可以创建自己的异常类。

从Exception类或者它的子类派生一个子类即可 。

习惯上,定义的类应该包含2个构造器:一个是默认的构造器,另一个是带有详细信息的构造器。

【示例3】自定义异常类


class    IllegalAgeException      extends   Exception {

public IllegalAgeException   () {

}

public IllegalAgeException   (String    msg) {

super(msg);

}

}

示例4】自定义异常类的使用


class Person {

private String name;

private int age;

public void setName(String name) {

this.name = name;

}

public void setAge(int age) {

if (age < 0)

throw new IllegalAgeException   ("人的年龄不应该为负数");

this.age = age;

}

public String toString() {

return "name is " + name + " and age   is " + age;

}

}

public class MyExceptionTest {

public static void main(String[] args) {

Person p = new Person();

try {

p.setName("Lincoln");

p.setAge(-1);

catch (IllegalAgeException    e) {

e.printStackTrace();

System.exit(-1);

}

System.out.println(p);

}

}


使用异常机制的建议

1. 要避免使用异常处理代替错误处理,这样会降低程序的清晰性,并且效率低下。

2.处理异常不可以代替简单测试--- 只在异常情况下使用异常机制

3.不要进行小粒度的异常处理---应该将整个任务包装在一个Try语句块中

4. 异常往往在高层处理(先了解!后面做项目会说!)

如何利用百度解决异常问题

正常学习和开发中,我们经常会遇到各种异常。大家在遇到异常时,需要遵循下面三步来解决:

1.  细心查看异常信息,确定异常种类和相关JAVA代码行号

2.  拷贝异常信息到百度,查看相关帖子,寻找解决思路

3.  前两步无法搞定,再问同学或同事。

4.  前三步无法搞定,请示领导。

很多同学碰到异常一下就慌了,立刻开始请教别人搬救兵,殊不知这样做有两大坏处。

第一、太不尊重别人,把别人当苦力。

第二、失去提高的机会,自己解决一个异常,就意味这有能力解决一类异常。

解决一个异常能大大提高自身能力。



「全栈Java笔记」是一部能帮大家从零到一成长为全栈Java工程师系列笔记。笔者江湖人称 Mr. G,10年Java研发经验,曾在神州数码、航天院某所研发中心从事软件设计及研发工作,从小白逐渐做到工程师、高级工程师、架构师。精通Java平台软件开发,精通JAVAEE,熟悉各种流行开发框架。

笔记包含从浅入深的六大部分:

A-Java入门阶段

B-数据库从入门到精通

C-手刃移动前端和Web前端

D-J2EE从了解到实战

E-Java高级框架精解

F-Linux和Hadoop

时间: 2024-10-29 10:54:49

6.3-全栈Java笔记:异常处理方法(上)的相关文章

6.2-全栈Java笔记:异常处理机制的分类

异常分类 JDK 中定义了很多异常类,这些类对应了各种各样可能出现的异常事件,所有异常对象都是派生于Throwable类的一个实例.如果内置的异常类不能够满足需要,还可以创建自己的异常类. 图1 异常的分类  Error Error类层次描述了Java运行时系统内部错误和资源耗尽错误.这类错误是我们无法控制的,同时也是非常罕见的错误.所以在编程中,不去处理这类错误. Error表明系统JVM已经处于不可恢复的崩溃状态中.我们不需要管他. 图2 java.lang包中Error的类 Error与E

6.1-全栈Java笔记:异常处理机制的概念

异常问题 实际工作中,遇到的情况不可能是非常完美的.比如:你写的某个模块,用户输入不一定符合你的要求.你的程序要打开某个文件,这个文件可能不存在或者文件格式不对,你要读取数据库的数据,数据可能是空的等.我们的程序再跑着,内存或硬盘可能满了等等. 软件程序在运行过程中,非常可能遇到刚刚提到的这些异常问题,我们叫异常,英文是:Exception,意思是例外.这些,例外情况,或者叫异常,怎么让我们写的程序做出合理的处理,安全的退出,而不至于程序崩溃. 如果我们要拷贝一个文件,在没有异常机制的情况下,我

6.4-全栈Java笔记:异常处理办法(下)

自定义异常 在程序中,可能会遇到任何标准异常类都没有充分的描述清楚的问题,这种情况下可以创建自己的异常类. 从Exception类或者它的子类派生一个子类即可 . 习惯上,定义的类应该包含2个构造器:一个是默认的构造器,另一个是带有详细信息的构造器. [示例1]自定义异常类 class    IllegalAgeException      extends   Exception { public IllegalAgeException   () { } public IllegalAgeExc

10.2-全栈Java笔记:最全面的IO技术(二)

上节我们聊到「IO技术概念及入门」这节我们继续聊一下IO技术的分类. Java中流的概念细分 按流的方向分类: 输入流:数据流向是数据源到程序(InputStream.Reader结尾的流) 输出流:数据流向是程序到目的地(OutPutStream.Writer结尾的流) 按处理的数据单元: 字节流:按照字节读取数据(InputStream.OutputStream)命名上以stream结尾的流一般是字节流. 字符流:按照字符读取数据(Reader.Writer).命名上以Reader/Writ

10.1-全栈Java笔记:最全面的IO技术(一)

IO技术 对于任何程序设计语言而言,输入输出(Input/Output)系统都是非常核心的功能.程序运行需要数据,数据的获取往往需要跟外部系统进行通信,外部系统可能是文件.数据库.其他程序.网络.IO设备等等. 外部系统比较复杂多变,那么我们有必要通过某种手段进行抽象.屏蔽外部的差异,从而实现更加便捷的编程. 输入(Input)指的是:可以让程序从外部系统获得数据(核心含义是"读",读取外部数据).常见的应用: 1) 读取硬盘上的文件内容到程序.例如:播放器打开一个视频文件.word打

15.1-全栈Java笔记:Java事件模型是什么?事件控制的过程有哪几步??

应用前边两节上一章节的内容,大家可以完成一个简单的界面,但是没有任何的功能,界面完全是静态的,如果要实现具体功能的话,必须要学习事件模型. 事件模型简介及常见事件模型 对于采用了图形用户界面的程序来说,事件控制是非常重要的. 一个源(事件源)产生一个事件并把它(事件对象)送到一个或多个监听器那里,监听器只是简单地等待,直到它收到一个事件,一旦事件被接收,监听器将处理这些事件. 一个事件源必须注册监听器以便监听器可以接收关于一个特定事件的通知. 每种类型的事件都有其自己的注册方法,一般形式为: v

14.4-全栈Java笔记: javax.swing常用控件有哪些?怎么用?

常用基本控件 javax.swing.JButton 在图形界面程序中,按钮可能是使用量最大的控件之一,javax.swing包中JButton类就是用来创建按钮的.如表1所示,为JButton常用的构造方法.  javax.swing.JLabel JLabel控件是最简单的Swing组件之一,用于在窗体上显示标签, JLabel既可以显示文本,也可以显示图像.如表3所示,为JLabel常用的构造方法. 注意: JLabel只能用于显示文本和图标信息,用户不能对其进行修改. javax.swi

13.3-全栈Java笔记:打飞机游戏实战项目|PaintThread|launchFrame

多线程和内部类实现动画效果 1)增加绘制窗口的线程类 前三个版本,我们步步为营,每个小版本都有功能的突破.但是,目前为止我们的窗口仍然是静态的,并没有像真正的游戏窗口那样"各种动.各种炫".本节我们结合多线程实现动画效果. 我们在MyGameFrame类中定义"重画窗口线程PaintThread类",为了方便使用MyGameFrame类的属性和方法,我们将PaintThread定义成内部类. [示例1]MyGameFrame类:增加PaintThread内部类 pu

4.6-全栈Java笔记:THIS关键字和STATIC关键字

this关键字 对象创建的过程和this的本质 构造方法是创建java对象的重要途径,通过new关键字调用构造器时,构造器也确实返回了该类的对象,但这个对象并不是完全由构造器负责创建的.创建一个对象分为如下四步: 1. 分配对象空间,并将对象成员变量初始化为0或空 2. 执行属性值的显示初始化 3. 执行构造方法 4. 返回对象的地址给相关的变量 this的本质就是"创建好的对象的地址"!  由于在构造方法调用前,对象已经创建.因此,在构造方法中也可以使用this代表"当前对