Java异常处理实例分析_java

本文实例讲述了Java异常处理的用法。分享给大家供大家参考。具体分析如下:

Java的异常处理机制可以帮助我们避开或者处理程序可能发生的错误,从而使得程序在遇到一些可恢复的错误的时候不会意外终止,而是去处理这些错误,也使得我们在写程序的时候不必写大量的代码来检查错误情况,增强了代码的可读性和逻辑性。在Java中,异常代表一个错误的实体对象。

异常可分为两类;一类是严重错误,如硬件错误、内存不足等,它们对应着java.lang包下的Error类及其子类。通常这类错误程序自身是无法恢复的,需要中断程序的执行;另一类是非严重的错误,如用户输入了非法数据,被0除等,它们对应着java.lang包中的Exception类及其子类,这种错误一般可以恢复,不影响程序的运行。
我们可以用try, catch,finally关键字来捕捉异常。

1、try, catch

将可能会发生异常的语句放到try{}块中,然后在catch{}语句块中捕捉即可。如被0除异常:

public class SimpleDemo
{
  //除法运算
  public static int devision(int a,int b)
  {
    return a / b;
  } 

  public static void main(String[] args)
  {
    try
    {
      //5除以0
      SimpleDemo.devision(5,0);
      System.out.println("Exception");
    }
    catch (Exception e)
    {
      e.printStackTrace();
    } 

    System.out.println("Finish");
  }
}

执行结果:

可以看到,Finish被打印了出来,说明程序并没有因为发生了被0除的错误而终止。
同时我们也发现,发生异常的SimpleDemo.devision()下面的System.out.println语句并没有被执行。一旦异常发生,程序就会从当前执行的位置跳出,而不会执行异常后面的语句。

2、finally

finally语句块中的语句无论异常有没有发生都会被执行。
有人可能会问,既然finally块中的语句无论异常有没有发生都会被执行,那么这个finally到底有什么实际作用呢?我不用finally直接写在外面不行么?
如上例,我们在catch语句块中加入一个return:

public class SimpleDemo
{
  //除法运算
  public static int division(int a,int b)
  {
    return a / b;
  }
  public static void main(String[] args)
  {
    try
    {
      //5除以0
      SimpleDemo.division(5,0);
      System.out.println("Exception");
    }
    catch (Exception e)
    {
      e.printStackTrace();
      return; //main函数返回
    }
    finally
    {
      System.out.println("Finally");
    }
    System.out.println("Finish");
  }
}

这时候,finally外面的Finish没有被打印,而finally块内部的Finally则被打印了出来。

finally在实际开发中非常有用。例如我们打开了一个数据库,在数据库读写数据的时候发生了异常,那么这时候就应该关闭数据库的连接,并释放相应的资源。这时候把释放资源的代码写在 finally块中是最合适不过的了。

但要注意的是,finally块在一种情况下是不会被执行的。如果程序在执行到finally块前退出了,如调用System.exit()方法,则 finally块也就得不到执行的机会了。

3、丢出异常

如果在一个方法中会有异常发生,但我们不想在方法中直接去处理这个异常,而是想让方法的调用者去处理,则可以使用throws关键字声明这个方法来丢出异常。这在Sun给我们提供的API函数中非常常见,如java.io.Reader中的read方法被声明为丢出一个IOException异常:

public int read(char[] cbuf)
     throws IOException

这时候我们在调用read方法时就必须将其放在try语句块中进行异常捕捉,否则编译器就会报错,强制我们进行异常捕捉。
当然,如果我们确实不想在调用read的时候处理异常,那么也可以把调用read方法的方法声明为throws IOException,这样异常就会再次被丢出。如果我们在main函数中声明丢出Exception异常,那么异常信息最终会被JVM捕获处理,而JVM的处理结果是,打印出异常信息,然后终止程序的运行。

4、异常处理的构架

所有的异常类都是从Exception类中派生而来的。这意味着,如果我们不确定会发生什么类型的异常,可以直接在catch中声明一个Exception对象,就能捕获到所有的Exception类及其子类的异常了。但要注意catch书写的顺序。如果在一个try后面有多个catch且第一个catch中声明的是Exception对象,那么这个异常就会直接被第一个catch处理,后面的catch都无法捕获到这个异常。这种错误在编译的时候就会以产生错误。如下例:

public class CatchDemo
{
  //除法运算
  public static int division(int a,int b)
  {
    return a / b;
  }
  public static void main(String[] args)
  {
    try
    {
      CatchDemo.division(4,0);
    }
    catch(Exception e)
    {
      System.out.println("Exception Class");
    }
    catch(ArithmeticException e)
    {
      System.out.println("ArithmeticException Class");
    }
  }
}

编译器输出  ArithmeticException已经被捕获了,意思就是说上面的Exception已经捕获了这个异常,无须重复捕获。

如果把这两个catch反过来会怎样呢?

public class CatchDemo
{
  //除法运算
  public static int division(int a,int b)
  {
    return a / b;
  }
  public static void main(String[] args)
  {
    try
    {
      CatchDemo.division(4,0);
    }
    catch(ArithmeticException e)
    {
      System.out.println("ArithmeticException Class");
    }
    catch(Exception e)
    {
      System.out.println("Exception Class");
    }
  }
}

这时候我们发现,代码通过了编译,且执行的结果是 ArithmeticException捕获了这个异常,而后面的catch则没有捕获到。

希望本文所述对大家的java程序设计有所帮助。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索java
异常处理
java异常处理实例、java异常处理的实例、c 异常处理实例、java异常实例、java异常类实例,以便于您获取更多的相关知识。

时间: 2024-09-24 22:16:47

Java异常处理实例分析_java的相关文章

Java异常处理实例教程_java

1.什么是异常? 首先,让我们来看看下图的例子: 在这个例子中,存在的错误码由除以0的结果.由于除以0而导致异常: ArithmeticException HelloException.java package com.yiibai.tutorial.exception; public class HelloException { public static void main(String[] args) { System.out.println("Three"); // This

Java中的多态用法实例分析_java

本文实例讲述了Java中的多态用法.分享给大家供大家参考.具体分析如下: 多态,是面向对象的程序设计语言最核心的特征.封装性.继承性都比较简单,所以这里只对多态做一个小小的笔记... 1.什么是多态? 多态意味着一个对象可以多重特征,可以在特定的情况下,表现出不同的状态,从而应对不同的属性和方法.在Java中,多态的实现指的是使用同一个实现接口,以实现不同的对象实例. 例如,我们定义一个Parent类,再定义一个getName()方法返回一个字符串,定义一个形参为Parent类型的成员方法doS

Java线程同步实例分析_java

本文实例讲述了Java线程同步的用法.分享给大家供大家参考.具体分析如下: 多线程的使用为我们的程序提供了众多的方便,同时它也给我们带来了以往没有考虑过的麻烦.当我们使用多线程处理共享资源时意外将会发生:比如我们一起外出就餐,每个人都是一个线程,餐桌上的食物则是共享资源,当我看到红烧鸡腿上桌后立即拿起筷子直奔目标,眼看着就得手的时候,突然---鸡腿消失了,一个距离盘子更近的线程正在得意地啃着. 为了避免上述问题的发生,Java为我们提供了"synchronized(同步化)修饰符"来避

java中request对象各种方法的使用实例分析_java

本文实例讲述了java中request对象各种方法的使用.分享给大家供大家参考,具体如下: request对象是从客户端向服务器端发出请求,包括用户提交的信息以及客户端的一些信息.request对象是javax.servlet.http.HttpServletRequest类的实现实例. request对象封装了浏览器的请求信息,通过request对象的各种方法可以获取客户端以及用户提交的各项请求信息. 使用request对象获取客户端提交的请求参数的常用方法如下: 1.String getPa

Java接口和抽象类实例分析_java

本文实例讲述了Java的接口和抽象类.分享给大家供大家参考.具体分析如下: 对于面向对象编程来说,抽象是它的一大特征之一.在Java中,可以通过两种形式来体现OOP的抽象:接口和抽象类.这两者有太多相似的地方,又有太多不同的地方.很多人在初学的时候会以为它们可以随意互换使用,但是实际则不然.今天我们就一起来学习一下Java中的接口和抽象类. 若有不正之处,请多多谅解并欢迎批评指正,不甚感激. 一.抽象类 在了解抽象类之前,先来了解一下抽象方法.抽象方法是一种特殊的方法:它只有声明,而没有具体的实

Java中递归原理实例分析_java

本文实例分析了Java中递归原理.分享给大家供大家参考.具体分析如下: 解释:程序调用自身的编程技巧叫做递归. 程序调用自身的编程技巧称为递归( recursion).递归做为一种算法在程序设计语言中广泛应用. 一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量.递归的能力在于用有限的语句来定义对象的无限集合.  递归的三个

Java中List与数组相互转换实例分析_java

本文实例分析了Java中List与数组相互转换的方法.分享给大家供大家参考.具体如下: 今天写代码遇到一个奇怪的问题,具体代码不贴出了,写一个简化的版本.如下: ArrayList<String> list=new ArrayList<String>(); String strings[]=(String [])list.toArray(); 这样写代码个人觉得应该没什么问题,编译也没有问题.可是具体运行的时候报异常,如下:Exception in thread "mai

java序列化与反序列化操作实例分析_java

本文实例分析了java序列化与反序列化操作.分享给大家供大家参考,具体如下: 概述: Java序列化是指把Java对象转换为字节序列的过程;而Java反序列化是指把字节序列恢复为Java对象的过程. 示例代码: import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.i

java之swing单选框用法实例分析_java

本文实例讲述了java之swing单选框用法.分享给大家供大家参考.具体如下: import java.awt.*; import javax.swing.*; import java.awt.event.*; public class test extends JApplet implements ActionListener{ JTextField jtf; public void init(){ Container contentPane = getContentPane(); conte