Java异常处理之throw与显示抛出异常

简介: 笔记

一、自定义异常类


实现自定义异常类需要继承Exception类或其子类,如果自定义运行时异常类需继承 RuntimeException类或其子类。

代码如下:

public class MyException extends Exception {
    public MyException(){
    }
    public MyException(String message){
        super(message);
    }
}


二、throw与显示抛出异常


throws用于方法后声明抛出异常,而throw关键字用来人工引发异常。

通过throw 语句显式抛出异常,语法格式如下:

throw Throwable或其子类的实例

所有Throwable或其子类的实例都可以通过throw语句抛出。

显式抛出异常目的有很多,例如不想某些异常传给上层调用者,可以捕获之后重新显式抛出另外一种 异常给调用者。

代码如下:

import java.io.*;
import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
//throw与显示抛出异常
public class HelloWorld {
    public static void main(String[] args) {
        try {
            Date date = readDate();
            System.out.println(date);
        } catch (MyException e) {
            e.printStackTrace();
        }
    }
    public static Date readDate() throws MyException {
        //        自动资源管理
//        调用FileInputStream()构造方法可能会发生FileNotFoundException异常,
        try (FileInputStream readfile = new FileInputStream("raedme.txt");
             InputStreamReader ir = new InputStreamReader(readfile);
             BufferedReader in = new BufferedReader(ir)) {
            //        读取文件中的一行数据, 调用BufferedReader输入流的readLine()方法可能会发生IOException异常
            String str = in.readLine();
            if (str == null) {
                return null;
            }
            //            调用SimpleDateFormat()方法可能会发生ParseException异常
            DateFormat df = new SimpleDateFormat("yyyy-MM-dd");
            java.util.Date date = df.parse(str);
            return date;
        } catch (FileNotFoundException e) {
            throw new MyException();
        } catch (IOException e) {
            throw new MyException(e.getMessage());
        } catch (ParseException e) {
            System.out.println("处理ParseException");
            e.printStackTrace();
        }
        return null;
    }
}

如果软件设计者不希望readDate()方法中捕获的FileNotFoundException和IOException异常出现在main() 方法(上层调用者)中,那么可以在捕获到FileNotFoundException和IOException异常时,通过throw语 句显式抛出一个异常,见代码throw new MyException(e.getMessage())语句, MyException是自定义的异常。


注意 throw显式抛出的异常与系统生成并抛出的异常,在处理方式上没有区别,就是两种方法: 要么捕获自己处理,要么抛出给上层调用者。在本例中是声明抛出,所以在readDate()方法后面要 声明抛出MyException异常。


相关文章
|
4天前
|
Java
在 Java 中捕获和处理自定义异常的代码示例
本文提供了一个 Java 代码示例,展示了如何捕获和处理自定义异常。通过创建自定义异常类并使用 try-catch 语句,可以更灵活地处理程序中的错误情况。
|
4天前
|
Java
在 Java 中,如何自定义`NumberFormatException`异常
在Java中,自定义`NumberFormatException`异常可以通过继承`IllegalArgumentException`类并重写其构造方法来实现。自定义异常类可以添加额外的错误信息或行为,以便更精确地处理特定的数字格式转换错误。
|
7天前
|
Java 编译器
探索Java中的异常处理机制
【10月更文挑战第35天】在Java的世界中,异常是程序运行过程中不可避免的一部分。本文将通过通俗易懂的语言和生动的比喻,带你了解Java中的异常处理机制,包括异常的类型、如何捕获和处理异常,以及如何在代码中有效地利用异常处理来提升程序的健壮性。让我们一起走进Java的异常世界,学习如何优雅地面对和解决问题吧!
|
5天前
|
IDE 前端开发 Java
怎样避免 Java 中的 NoSuchFieldError 异常
在Java中避免NoSuchFieldError异常的关键在于确保类路径下没有不同版本的类文件冲突,避免反射时使用不存在的字段,以及确保所有依赖库版本兼容。编译和运行时使用的类版本应保持一致。
|
6天前
|
Java 编译器
如何避免在 Java 中出现 NoSuchElementException 异常
在Java中,`NoSuchElementException`通常发生在使用迭代器、枚举或流等遍历集合时,尝试访问不存在的元素。为了避免该异常,可以在访问前检查是否有下一个元素(如使用`hasNext()`方法),或者使用`Optional`类处理可能为空的情况。正确管理集合边界和条件判断是关键。
|
7天前
|
Java 开发者
Java中的异常处理:从基础到高级
【10月更文挑战第35天】在Java的世界里,异常处理是维护程序健壮性的关键。本文将深入浅出地探讨Java的异常处理机制,从基本的try-catch语句到自定义异常类的实现,带领读者理解并掌握如何在Java中优雅地处理错误和异常。我们将通过实际代码示例,展示如何捕获、处理以及预防潜在的运行时错误,确保程序即使在面临意外情况时也能保持稳定运行。
22 7
|
6天前
|
Java 数据库连接 开发者
Java中的异常处理机制及其最佳实践####
在本文中,我们将探讨Java编程语言中的异常处理机制。通过深入分析try-catch语句、throws关键字以及自定义异常的创建与使用,我们旨在揭示如何有效地管理和响应程序运行中的错误和异常情况。此外,本文还将讨论一些最佳实践,以帮助开发者编写更加健壮和易于维护的代码。 ####
|
13天前
|
Java 程序员 数据库连接
Java中的异常处理:理解与实践
【10月更文挑战第29天】在Java编程的世界里,异常像是不请自来的客人,它们可能在任何时候闯入我们的程序宴会。了解如何妥善处理这些意外访客,不仅能够保持我们程序的优雅和稳健,还能确保它不会因为一个小小的失误而全盘崩溃。本文将通过浅显易懂的方式,带领读者深入异常处理的核心概念,并通过实际示例展现如何在Java代码中实现有效的异常管理策略。
|
22天前
|
Java 开发者
Java中的异常处理:理解与实践
【10月更文挑战第20天】在Java编程的世界中,异常处理是一个不可忽视的重要话题。它不仅关乎代码的健壮性,更是程序设计中体现开发者预见性和解决问题能力的关键所在。本文将通过深入浅出的方式,带领读者探索Java异常处理的核心概念、实践方法以及如何优雅地应对各种异常情况,让你的代码在面对意外时也能从容不迫。
11 1
|
1月前
|
安全 Java UED
Java中的异常处理:理解与实践
【10月更文挑战第8天】在Java的世界里,异常处理是维护代码健壮性的守护神。本文将带你深入探索Java的异常处理机制,从基础的try-catch语句到高级的自定义异常,再到最佳实践和性能考量,我们将一起学习如何优雅地处理程序中的错误和异常情况。准备好,让我们一起迎接挑战,确保你的Java代码既安全又高效!