Java:Exception
异常:
就是程序在运行时出现不正常的情况。
异常的由来:问题也是现实生活中一个具体的事物,也可以通过java的类的形式进行描述,并封装成对象。其实就是Java对不正常情况进行描述后的对象的体现。
两种问题:
严重问题(Error)、非严重问题(Exception)。
Error和Exception具有一些共性内容。(都是Throwable的子类)
try
{
需要被检测的代码
}
catch(异常类 变量)
{
处理异常的代码;(处理方式)
}
严重问题:
Java通过Error类进行描述。对于Error一般不编写针对性的代码对其进行处理。
非严重问题:
Java通过Exception类进行描述。对Exception可以使用针对性的代码进行处理。
异常的处理:
try
{
需要被检测的代码
}
catch(异常类 变量)
{
处理异常的代码;(处理方式)
}
异常的常见操作:
getMessage() :返回信息:异常原因
toString():反馈信息:异常类+异常原因
printStackTrace():反馈堆栈中的异常信息 异常类+异常原因+异常出现的位置,其实jvm默认的异常处理机制就是在调用printStackTrace方法
例如,除数是零
class Demo
{
int div(int a, int b)
{
return a/b;
}
} class ExceptionDemo
{
public static void main(String[] args)
{
Demo d = new Demo();
try
{
int x = d.div(4,0);//捕获到异常对象 new AritchmeticException()
System.out.println("x=" + x);
}
catch (Exception e)//把捕获到的异常给了catch: Exception e = new AritchmeticException();
{
System.out.println("除数是零!");
System.out.println(e.getMessage());
System.out.println(e.toString());
e.printStackTrace();
} System.out.println("Program Over!");
}
}
但我们在定义Class时就应该提示是否会出现异常,提醒调用该Class时是需要处理Exception。当调用者使用该Class时,必须捕获该类的异常进行处理或者抛出。
捕获:try-catch处理
class Demo
{
int div(int a, int b)throws Exception//在功能上通过throws关键字声明了该功能在使用时有可能出现问题
{
...
}
} class ExceptionDemo
{
public static void main(String[] args)
{
Demo d = new Demo();
try
{
...
}
catch (Exception e)
{
...
}
}
}抛出:调用该有标识异常的类的方法上通过throws抛出,不处理
class Demo
{
int div(int a, int b)throws Exception//在功能上通过throws关键字声明了该功能在使用时有可能出现问题
{
...
}
} class ExceptionDemo
{
public static void main(String[] args)throws Exception
{
...
}
}
·声明异常时,建议声明更为具体的异常,这样处理的可以更具体。
例如上面的例子,可以把异常由Exception更改为ArithmeticExcption
·有多个异常时,可以针对性用多个catch处理。如果多个异常有继承关系,父类异常的catch放在最下面
建议进行catch处理时,catch中一定要定义具体的处理方式,不要简单的使用printStackTrace()等等
class Demo
{
int div(int a, int b)throws ArithmeticException,ArrayIndexOutOfBoundsException//抛出多个异常
{ int[] arr = new int[a];
System.out.println(arr[5]);//可能出现异常的地方 return a/b;//可能出现异常的地方
}
} class ExceptionDemo
{
public static void main(String[] args)
{
Demo d = new Demo();
try
{
int x = d.div(4,0);
System.out.println("x=" + x);
}
catch (ArithmeticException e)//处理异常
{
System.out.println("除数是零!");
e.printStackTrace();
}
catch (ArrayIndexOutOfBoundsException e)//处理异常
{
System.out.println("数组角标异常!");
e.printStackTrace();
} System.out.println("Program Over!");
}
}
自定义异常:
因为项目中会出现特有问题,而这些问题是Java未对其描述并封装成对象。所以对这些特有问题可以按照Java对问题的封装思想,对其封装。
当在函数内部出现了throw抛出异常对象,那么就必须要给出对应的处理。要么在内部try-catch,要么在函数上声明让调用者处理。 一般情况下,函数内出现异常,函数上需要声明。
如何自定义异常信息呢?
因为父类已经把异常信息的操作都完成了,所以子类只要在构造时,将异常信息传递给父类,通过super语句。那么就可以直接通过getMessage方法获取自定义的异常信息了。
继承Exception的原因
异常体系都有一个特点:异常类和异常对象都被抛出。
他们都具有可抛性,是Throwable这个体系的独有特点。只有这个体系中的类和对象才可以被throws和throw操作。
throws 和 throw 的区别:
1,throws使用在函数上,throw使用在函数内
2,throws后面跟的是异常类,可以跟多个,用逗号隔开;throw后跟的是异常对象
/*
需求:在本程序中,不允许除数为负数。
因为该需求是特殊要求,所以要对这个问题进行自定义的描述;
*/
class DefinedException extends Exception
{
private int value; DefinedException()
{
System.out.println("自定义异常的空参数的构造函数:除数不能为负数");
}
DefinedException(String msg)
{
super(msg);
}
DefinedException(String msg, int value)
{
super(msg);
this.value = value;
} public int getValue()
{
return value;
}
} class Demo
{
int div(int a,int b)throws DefinedException
{
if (b<0)
{
//throw new DefinedException();
//throw new DefinedException("除数不能为负数!");
throw new DefinedException("除数不能为负数!",b);//手动通过throw抛出
}
return a/b;
}
}
class DefinedExceptionDemo
{
public static void main(String[] args)
{
Demo d = new Demo();
try
{
int x = d.div(4,-1);
System.out.println("a/b="+x);
}
catch (DefinedException e)
{
System.out.println("除数不能为负数!");
System.out.println("错误的数是:"+e.getValue());
//d.printStackTrace();
} System.out.println("Program Over!");
} }
RuntimeException:
Exception中有一个特殊的子类异常RuntimeException 运行时异常。
RuntimeException或者其子类的异常,可以不用在函数上使用throws申明。如果在函数上申明了该异常,调用者可以不用处理就可以通过编译。不申明的原因:当程序运行时遇到该异常,导致下面的程序不能预期运行,希望停止运行后修正该程序。(比如如果一个函数只申明了一个异常,而在函数内抛出了三个异常,那么另外两个异常必然就是RuntimeException或者其子类)
自定义异常时,如果该异常发生后无法继续工作,就让该异常继承RuntimeException
异常分两种:
1,编译时被检测的异常
2,编译时不被检测的异常,但运行时异常。RuntimeException及其子类
finally:
finally中的代码是一定会执行的代码,一般存放必须要操作的内容比如释放与数据库的连接、关闭IO等等。
finally只有一种情况不会被执行到:finally前面有System.exit(0)
异常处理的三种各式:
1, try-catch
2, try-catch-finally
3, try-fiinally
异常在子父类覆盖时的体现:
1,子类在覆盖父类方法时,如果父类的方法抛出异常,那么子类的覆盖方法只能抛出父类的异常或者该异常的子类
2,如果父类方法抛出多个异常,那么子类在覆盖该方法时,只能抛出父类异常的子集
3,如果父类或者接口的方法中,没有异常抛出,那么子类在覆盖方法时也不可以抛出异常
如果子类方法发生了异常,就必须要try处理,绝对不能抛。
Java:Exception的更多相关文章
- MyEclipse8.5集成Tomcat7时的启动错误:Exception in thread “main” java.lang.NoClassDefFoundError org/apache/commons/logging/LogFactory
今天,安装Tomcat7.0.21后,单独用D:\apache-tomcat-7.0.21\bin\startup.bat启动web服务正常.但在MyEclipse8.5中集成配置Tomcat7后,在 ...
- MyEclipse8.5集成Tomcat7时的启动错误:Exception in thread “main” java.lang.NoClassDefFoundError org/apache/commons/logging/LogFactory
今天,安装Tomcat7.0.21后,单独用D:\apache-tomcat-7.0.21\bin\startup.bat启动web服务正常.但 在MyEclipse8.5中集成配置Tomcat7后, ...
- 【转】MyEclipse8.5集成Tomcat7时的启动错误:Exception in thread “main” java.lang.NoClassDefFoundError org/apache/commons/logging/LogFactory
http://www.cnblogs.com/newsouls/p/4021198.html 今天,安装Tomcat7.0.21后,单独用D:\apache-tomcat-7.0.21\bin\sta ...
- java菜鸟篇<二> eclipse启动tomcat报错的问题:Exception: java.lang.OutOfMemoryError thrown from the UncaughtExceptionHandler in thread "main"
9.1今天不知道自己瞎搞eclipse的时候按到了什么键,然后再启动程序的时候就会报错: 如下: Exception: java.lang.OutOfMemoryError thrown from t ...
- spark-shell报错:Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/hadoop/fs/FSDataInputStream
环境: openSUSE42.2 hadoop2.6.0-cdh5.10.0 spark1.6.0-cdh5.10.0 按照网上的spark安装教程安装完之后,启动spark-shell,出现如下报错 ...
- 报错:Exception in thread "main" java.lang.NoClassDefFoundError: Lorg/apache/hadoop/fs/FileSystem
报错现象: Exception in thread "main" java.lang.NoClassDefFoundError: Lorg/apache/hadoop/fs/Fil ...
- 【tomcat】启动报错:Failed to initialize end point associated with ProtocolHandler ["http-apr-8080"] java.lang.Exception: Socket bind failed 和java.net.BindException: Address already in use: JVM_Bind错误解决
背景:[新手] 将开发机子上的Tomcat连同其中的项目,一起拷贝到服务器上,启动tomcat的start.bat,然后报错如下: 问题1: Failed to initialize end poin ...
- Oracle EM错误,java.lang.Exception: Exception in sending Request :: null 分类: Oracle 2015-07-08 21:24 44人阅读 评论(0) 收藏
操作系统:Win7 64bit Oracle: 10.2.0.1.0 很久没有使用EM了,打开一看,居然报错了,出现java.lang.Exception: Exception in sending ...
- “全栈2019”Java异常第十八章:Exception详解
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java异 ...
随机推荐
- Java初始化(构造器)
在类的内部,变量定义的先后顺序决定了初始化的顺序.即使变量定义散布于方法定义之间,它们仍旧会在任何方法(包括构造器)被调用之前得到初始化. import static humeng.com.cnblo ...
- [转载] 数据库分析手记 —— InnoDB锁机制分析
作者:倪煜 InnoDB锁机制常常困扰大家,不同的条件下往往表现出不同的锁竞争,在实际工作中经常要分析各种锁超时.死锁的问题.本文通过不同条件下的实验,利用InnoDB系统给出的各种信息,分析了锁的工 ...
- 初学CDQ分治-NEU1702
关于CDQ分治,首先需要明白分治的复杂度. T(n) = 2T(n/2)+O(kn), T(n) = O(knlogn) T(n) = 2T(n/2)+O(knlogn), T(n) = O(knlo ...
- 线程高级应用-心得6-java5线程并发库中同步工具类(synchronizers),新知识大用途
1.新知识普及 2. Semaphore工具类的使用案例 package com.java5.thread.newSkill; import java.util.concurrent.Executor ...
- Android Menu菜单使用
如上图右上角,菜单选项的编辑,第一种代码实现方式如下: package com.example.menu; import android.os.Bundle; import android.app.A ...
- JavaSE复习_10 多线程复习
△wait()和sleep()的区别: 1.wait():没有等待时间,而sleep()需要有等待时间作为参数. 2.在同步中对于CPU的执行权和锁的处理不同: wait()会释放执行权和锁. ...
- TextView使用SpannableString设置复合文本
TextView通常用来显示普通文本,但是有时候需要对其中某些文本进行样式.事件方面的设置.Android系统通过SpannableString类来对指定文本进行相关处理,具体有以下功能: 1.Bac ...
- LCA模板
/*********--LCA模板--***************/ //设置好静态参数并构建好图的邻接表,然后调用lca_setquery()设置查询 //最后调用lca_start(),在lca ...
- virtualbox中centos系统配置nat+host only上网(zhuan)
http://www.cnblogs.com/leezhxing/p/4482659.html **************************************************** ...
- 转!!!Mybatis实现数据的增删改查(CRUD)
什么是 MyBatis? MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架. MyBatis 消除了几乎所有的 JDBC 代码和参数的手工设置以及对结果集的检索.MyBat ...