【Java异常】自定义异常

article/2025/10/2 9:00:55

Java中定义了大量的异常类,虽然这些异常类可以描述编程时出现的大部分异常情况,但是在程序开发中有时可能需要描述程序中特有的异常情况,例如在设计divide()方法时不允许被除数为负数。为了解决这样的问题,Java允许用户自定义异常,但自定义的异常类必须继承自Exception 或其子类。
我们先定义一个异常类继承自Exception,如下:

public class DivideByMinusException extends Exception{public DivideByMinusException() {super();//调用Exception的无参构造方法}public DivideByMinusException(String message) {super(message);//调用Exception的有参构造方法}}

在实际开发中.如果没有特殊的要求,自定义的异常类只需继承Exception类,在构造方法中使用super()语句调用Exception 的构造方法即可。

既然自定义了异常,那么该如何使用呢?这时就需要用到throw 关键字,在程序指定位置通过throw关键字抛出自定义的异常对象,然后对抛出的异常进行异常处理。

接下来重新对例中的divide()方法进行改写,在divide()方法中判断被除数是否为负数,如果为负数,就是用throw关键字向调用者抛出自定义的DivideByMinusException异常对象

如下:

public class Dmeo03 {//下面两种方法实现了两个整数相除public static int divide(int x,int y) throws DivideByMinusException{if(y<0) {//使用throw关键词声明异常对象throw new DivideByMinusException("除数<0");}int result = x/y;//定义一个变量result记录两个数相除的结果 return result;//将结果返回}public static void main(String[] args) {try {int result = divide(4,-2);System.out.println(result);}catch(DivideByMinusException e) {System.out.println("捕获的异常信息为:"+e.getMessage());}}}

运行结果:

divide()方法通过逻辑判断对除法运算的除数是否为0进行了判断,如果除数为0就使用throw关键字抛出自定义的DivideByMinusException异常对象,然后通过throws关键字抛出异常,并在最后通过try...catch语句捕获异常。从上图可以看出,程序执行后判断出除数为0,抛出了指定的异常信息。

感谢观看!!!
 


http://chatgpt.dhexx.cn/article/sbg6cmCV.shtml

相关文章

JAVA项目中自定义异常

JAVA项目中自定义异常 1.数据返回处理类 Data public class R<T> implements Serializable {private static final long serialVersionUID -8497670085742879369L;ApiModelProperty(value "返回码", example "200")private Integer code200;Api…

Java自定义异常理解

前言&#xff1a;看了许多博客和书&#xff0c;都对自定异常一笔带过&#xff0c;总让人感觉莫名奇妙&#xff0c;一直在问自己一个问题&#xff0c;我们能很好的解决异常就很不错了&#xff0c;为什么还要自己自定义异常&#xff0c;让自己去自找麻烦呢&#xff1f;后来我才理…

Java自定义异常

使用Java内置的异常类可以描述在编程时出现的大部分异常情况。除此之外&#xff0c;用户还可以自定义异常。用户自定义异常类&#xff0c;只需继承Excepition类即可 在程序当中自定义异常类&#xff0c;大体可以分成几个步骤&#xff1a; 1.创建自定义异常类 2.在方法中通过t…

JAVA 基础学习之异常机制

异常机制 1、概念 异常指程序运行过程中出现的非正常现象&#xff0c;例如用户输入错误、除数为零、需要处理的文件不存在、数组下标越界等。在Java的异常处理机制中&#xff0c;引进了很多用来描述和处理异常的类&#xff0c;称为异常类。 2、异常的分类 Throwable下面又派生…

【Java】自定义异常

自定义异常&#xff1a; java提供的异常类&#xff0c;不够我们使用&#xff0c;需要自己定义一些异常类 格式&#xff1a; public class XXException extends Exception|RuntimeException{ 添加一个空参数的构造方法 添加一个带异常信息的构造方法 } 注意&#xff1a; 1.自…

Java异常详解及自定义异常

我已经不用 try catch 处理异常了&#xff01;太烦人了_51CTO博客_try catch处理什么异常 一、异常的概念 1.定义&#xff08;什么是异常&#xff1f;&#xff09; 异常是例外&#xff0c;是一个程序在执行期间发生的事件&#xff0c;它中断正在执行程序的正常指令流。软件开发…

哈夫曼树(带权路径长度+树的带权路径长度+哈夫曼树定义+构造哈夫曼树+哈夫曼树性质+哈夫曼编码+计算平均码长-这里指WPL)

带权路径长度 树的带权路径长度WPL 哈夫曼树 哈夫曼树构造 哈夫曼树性质 哈夫曼编码 固定长度编码 可变长编码 前缀编码 固定长度编码、可变长编码、前缀编码、哈夫曼编码 思维倒图 试题

哈夫曼树——【实例】利用3,6,8,12,5,7这六个值作为叶子结点的权,由该权值集合构造的哈夫曼树中带权路径长度之和为多少,该树的深度为多少。

利用3&#xff0c;6&#xff0c;8&#xff0c;12&#xff0c;5&#xff0c;7这六个值作为叶子结点的权&#xff0c;由该权值集合构造的哈夫曼树中带权路径长度之和为多少&#xff0c;该树的深度为多少。 基础知识 哈夫曼树是一种带权路径长度最短的二叉树&#xff0c;也称为最优…

哈夫曼树(最优二叉树:带权路径长度最短的树(度相同的情况下))

基本概念 1、结点的路径长度&#xff1a;两结点间间路径上的分支数 2、树的路径长度&#xff1a;从根结点到每一个结点的路径长度之和 3、结点的带权路径长度&#xff1a;从根结点到该结点之间的路径长度与该结点的权的乘积 4、树的带权路径长度&#xff1a;树中所有叶子结…

已知权值的哈夫曼树,求带权路径长度

转自牛客网 有权值分别为11&#xff0c;8&#xff0c;6&#xff0c;2&#xff0c;5的叶子结点生成一棵哈夫曼树&#xff0c;它的带权路径长度为_______。

哈夫曼树-创建,编码,解码,带权路径长度(含全部代码)

目录 主要函数 所选实例 创建哈夫曼树 步骤 【分析】 哈夫曼树结构 注意项 代码 创建哈夫曼树结果截图 编码 【分析】 代码 哈夫曼树编码结果截图 解码 【分析】 代码 哈夫曼树解码结果截图 计算带权路径长度 【分析】 代码 计算带权路径长度结果截图 全…

求哈夫曼的带权路径长度

【问题描述】 已知输入两行正整数&#xff0c;第二行正整数之间用空格键分开&#xff0c;请建立一个哈夫曼树&#xff0c;以输入的数字为叶节点&#xff0c;求这棵哈夫曼树的带权路径长度。 【输入形式】 首先第一行为输入正整数的个数&#xff0c;然后接下来的一行正整数&a…

构造哈夫曼树以及求哈夫曼编码、树的带权路径长度

我们先搞清楚这几个概念 构造哈夫曼树的方法 将每种字符出现的频率先收集起来放在最上方&#xff0c;然后选择两个频率最小的增加到图中&#xff0c;并将他们的和作为他们的父节点&#xff0c;增加到图中&#xff0c;在最上方删除选择的两个节点&#xff08;4和2&#xff09;&a…

哈夫曼树的构建与最小带权路径长度

注意&#xff1a;哈夫曼树并不唯一&#xff0c;但带权路径长度一定是相同的。 二叉树&#xff1a;每个结点最多含有两个子树的树称为二叉树。定理&#xff1a;对于具有n个叶子结点的哈夫曼树,共有2n-1个结点。 哈夫曼树介绍 1哈夫曼树的定义 哈夫曼&#xff08;Huffman&…

创建哈夫曼树并求带权路径长度

创建哈夫曼树并求带权路径长度 【问题描述】根据给定的权重&#xff0c;构造哈夫曼树&#xff0c;输出其带权路径长度。 【输入形式】输入权重&#xff0c;空格作为分隔&#xff0c;回车结束&#xff0c;权重个数小于10。 【输出形式】哈夫曼树的带权路径长度。 【样例输入】5…

哈夫曼树(构建以及计算加权路径长度)

今天做远景的笔试题&#xff0c;遇到了这么一道题&#xff0c;求{11,8,6,5,2}构成的哈夫曼树的加权路径长度。 好长时间没看数据结构&#xff0c;居然忘记怎么求了&#xff0c;该死。 考完下百度&#xff0c;好多答案居然都是错的。或者是光有答案没有过程。在这里把哈夫曼树的…

哈夫曼树的构建、编码以及带权路径长计算

给定n个权值作为n个叶子结点&#xff0c;构造一棵二叉树&#xff0c;若该树的带权路径长度达到最小&#xff0c;称这样的二叉树为最优二叉树&#xff0c;也称为哈夫曼树(Huffman Tree)。哈夫曼树是带权路径长度最短的树&#xff0c;权值较大的结点离根较近。 构造哈夫曼树的算…

哈夫曼树与带权路径长度

问题&#xff1a; 权值分别为从19&#xff0c;21&#xff0c;2&#xff0c;3&#xff0c;6&#xff0c;7&#xff0c;10&#xff0c;32的结点&#xff0c;构造一棵哈夫曼树&#xff0c;该树的带权路径长度是&#xff1f; 哈夫曼树的一个应用&#xff1a; 压缩字符串https://…

哈夫曼树 和 树的带权路径长度

树的带权路径长度(Weighted Path Length of Tree)&#xff1a;定义为树中所有叶结点的带权路径长度之和。 结点的带权路径长度&#xff1a;结点到树根之间的路径长度与该结点上权的乘积。 哈夫曼树是一种带权路径长度最短的二叉树&#xff0c;也称为最优二叉树。 哈夫曼树构建…