写了一天的bug,来try...catch...finally了解一下。异常是程序中的一些错误,但并不是所有的错误都是异常,并且错误有时候是可以避免的。在使用IDE编程的时候,会出现一些红色的波浪线(编译都过不了)【受查异常】,Alt+Enter键还提示add exception to method... 和.. with try/catch。按照提示加了之后运行,mmp 控制台又出现Exception in thread ... at java ...【非受查异常】。这Exception跟我过不去了,真是的让不让人愉快的写bug了。不说了先看看看Java异常类层次结构图



JAVA异常

  • Throwable:是Java语言中所有错误(Error)和异常(Exception)的父类,只有当对象是此类(或其子类之一)的实例时,才能通过 Java 虚拟机或者 Java throw 语句抛出。
  • Error(错误):一般是指虚拟机相关的问题,如系统崩溃、虚拟机错误、动态链接失败等,这种错误无法恢复或不可能捕获,将导致应用程序中断。通常应用程序无法处理这些错误。
  • Exception:是程序本身可以处理的异常。

Java异常分为两大类:

可查异常(编译器要求必须处置的异常):除RuntimeException类及其子类的异常以及Error外。要么显示声明抛出异常,要么显示捕获并处理它。

不可查异常(编译器不要求强制处置的异常):所有的 RuntimeException类及其子类的异常和 Error(错误)。

异常的处理机制

  • 使用 try...catch 或 try...catch...finally 捕获异常
 try {
FileInputStream fis = new FileInputStream("E:\\a.txt");
System.out.println(fis.available());
}catch (IOException e){
e.printStackTrace();
}
 FileInputStream fis = null;
try {
fis= new FileInputStream("E:\\a.txt");
System.out.println(fis.available());
}catch (IOException e){
e.printStackTrace();
//System.exit(1); 退出虚拟机,finally将不会执行
}finally {
// java垃圾回收机制不会回收任何物理资源,只能回收堆内存中的对象
if(fis != null){ // 关闭磁盘文件,回收资源
try {
fis.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}

尽量避免在finally块里使用return 或 throw 等导致语句方法终止的语句,否则可能出现一些奇怪的情况

情况1:文件存在,会先执行try块,再执行finally块,执行最后面return语句,返回 int类型的值 1
文件不存在,不会执行try块输出语句,执行catch块,再执行finally块,执行最后面return语句,返回int类型的值 1 情况2:文件存在,会先执行try块非return语句,执行return语句,再执行 finally块非return语句,执行return语句,返回finally中int类型的值 1
文件不存在,不会执行try块输出语句及之后的语句,执行catch块非return语句,执行return语句,再执行finally块非return语句,执行return语句,返回finally中int 类型的值1 情况3:文件不存在,不会执行try块输出语句,执行catch块非return语句,执行return语句,再执行finally块非return语句,执行return语句,返回finally中int 类型的值 1 情况4:文件不存在,不会执行try 块输出语句,执行catch块非return语句,执行return语句,再执行finally块,不执行最后的return语句,返回catch中int类型的值 0 情况5:文件存在,会先执行try块,再执行finally块,不执行最后面的return语句,返回try中int类型的值 0
文件不存在,不会执行try块输出语句及之后的语句,执行catch块,再执行finally块,执行最后面的return语句,返回 int类型的值 1
public class Test0022{
public static void main(String [] args){
System.out.println("返回的值为:"+new ReadDiskE().read());
}
} class ReadDiskE{
public int read(){
try {
FileInputStream fis = new FileInputStream("E:\\a.ba");
System.out.println("try 块");
//return 0; // 情况2
return 0; // 情况5
}catch (IOException e){
System.out.println("catch 块");
//return 0; // 情况3
//return 0; // 情况4
}finally {
System.out.println("finally 块");
//return 1; // 情况2 一般放到括号外
//return 1; // 情况3
}
//return 1; // 情况1
//return 1; // 情况4
return 1; // 情况5
}
}

总结:

try 捕获异常交给catch处理,catch若无法处理则交给调用者处理,若无法处理则交给虚拟机处理抛出异常。

try 块:用于捕获异常。其后可接零个或多个catch块,如果没有catch块,则必须跟一个finally块。

catch 块:用于处理try捕获到的异常。

finally 块:无论是否捕获或处理异常,finally块里的语句都会被执行。当在try块或catch块中遇到return语句时,finally语句块将在方法返回之前被执行。以下4种特殊情况下,finally块不会被执行:

1)在finally语句块中发生了异常。

2)在前面的代码中用了System.exit()退出程序。

3)程序所在的线程死亡。

4)关闭CPU。

  • 使用 throws 声明抛出异常

    当方法不知道如何处理这种异常时,该异常应该由上一级调用者处理;如果main方法也不知道如何处理,也可以使用throws声明throws 声明抛出异常,该异常将交给JVM处理。JVM对异常的处理是:打印异常的跟踪栈信息,并中止程序运行。
public static void main(String [] args) throws Exception {
//调用test方法声明抛出IOException异常
//所以调用该方法代码要么在 try...catch中,要么在带 throws声明的方法中
test();
}
public static void test() throws IOException {
FileInputStream fis = new FileInputStream("E:\\a.txt");
}
  • 使用 throw 抛出异常

    当程序出现错误时,系统会自动抛出异常;Java也允许程序自行抛出异常,自行抛出异常使用 throw语句完成。
public class Test0022{
public static void main(String [] args){
try {
test0();
test();
}catch (FileNotFoundException e){ // 捕获异常,先捕获小异常,再捕获大异常。
e.printStackTrace();
// 注释 throw e 后,程序继续运行(异常被吃掉了)
//throw e; // 继续抛出,由main方法处理,程序终止(main方法需要throws 声明抛出异常)。
}catch (IOException e1){
e1.printStackTrace();
}
System.out.println("------test or test0 end-----"); // 调用声明 Runtime 异常的方法既可以显示捕获该异常,也可不理会
test1(-1); // 交给main方法抛出异常,程序终止
System.out.println("------test1 end-----"); // 不打印该语句
}
public static void test() throws IOException {
System.out.println("test");
throw new IOException("I'm an IOException");
}
public static void test0() throws FileNotFoundException{
System.out.println("test0");
throw new FileNotFoundException("I'm a FileNotFoundException");
}
public static void test1(int i){
if(i < 0){
System.out.println("test1");
throw new RuntimeException("I'm an RuntimeException");
}
}
}

自定义异常

通常情况,程序很少会自行抛出系统异常,因为异常的类名通常也包含了该异常的有用信息。所以在选择抛出异常时,应该选择合适的异常,从而可以明确的描述该异常的情况。

用户自定义的异常都应该继承 Exception的基类,如果希望自定义Runtime 异常,则应该继承RuntimeException基类。

public class Test0022{
public static void main(String [] args){
try{
throw new AutionException("我是自定义异常");
}catch (AutionException e){
e.initCause(new Throwable("初始化原因"));
System.out.println(e.getMessage()); // 打印 "我是自定义异常" , 返回此throwable的详细消息字符串。
System.out.println(e.getLocalizedMessage()); // 打印 "我是自定义异常", 创建此可抛出的本地化描述。
System.out.println(e.getCause().toString());//打印 "java.lang.Throwable: 初始化原因",将此throwable的原因初始化为指定值
StackTraceElement[] trace = e.getStackTrace(); // 提供编程访问由 printStackTrace() 输出的堆栈跟踪信息
for (int i=0; i<trace.length;i++){
StackTraceElement ste = trace[i];
System.out.println("i:"+i+"--"+ste.toString()); // e.printStackTrace();
System.out.println("i:"+i+"--"+ste.getClassName()); // 返回堆栈信息类名的完整信息 com.zzw.test005.Test0022
System.out.println("i:"+i+"--"+ste.getMethodName()); // 返回方法名 main
System.out.println("i:"+i+"--"+ste.getLineNumber()); // 返回报错的行数 4
System.out.println("i:"+i+"--"+ste.getFileName()); // 返回类所在的文件名 Test0022.java
}
}
}
} // 自定义异常类
class AutionException extends Exception{ public AutionException(){} public AutionException(String msg){
super(msg);
}
}

注:

推荐阅读博客:https://blog.csdn.net/hguisu/article/details/6155636

参考书籍《Java疯狂讲义》

Java_异常以及处理的更多相关文章

  1. java_异常

    一.什么是异常? 1.当程序”运行后”,当jvm遇到一些无法处理的情况,例如:整数/0,这就表示jvm遇到一种”异常情况”. 通常jvm能够识别这些异常并在控制台打印异常信息,并结束程序 2.为了解决 ...

  2. Java_异常_05_ OutOfMemoryError: Java heap space

    一.异常现象: 二.异常原因 JAVA的堆栈设置太小 注: 出现此异常之后,会引发其他的问题. 三.异常解决 手动设置Heap size: 修改 TOMCAT_HOME/bin/catalina.sh ...

  3. Java_异常_03_ java.lang.NoClassDefFoundError: org/apache/commons/pool/KeyedObjectPoolFactory

    异常信息: java.lang.NoClassDefFoundError: org/apache/commons/pool/KeyedObjectPoolFactory 原因: 我用的是commons ...

  4. Java_异常_02_java.lang.NoClassDefFoundError: org/apache/log4j/Level

    总结:解析Json时,除了要导入json-lib-2.2-jdk15.jar外,还要导入: commons-beanutils.jar, commons-httpclient.jar, commons ...

  5. Java_异常_01_org.apache.commons.lang.exception.NestableRuntimeException

    异常信息: The type org.apache.commons.lang.exception.NestableRuntimeException cannot be resolved. It is ...

  6. Java_异常介绍

    今日内容介绍: 掌握异常概述 理解异常的基础操作以及最简单的捕获处理 理解多异常捕获处理 理解声明抛出异常 掌握自定义异常 掌握异常处理注意事项 异常 什么是异常?Java代码在运行时期发生的问题就是 ...

  7. Java_异常_06_ Unsupported major.minor version 52.0

    二.参考资料 1.如何解决Unsupported major.minor version 52.0问题? 2.Unsupported major.minor version 52.0 3. Unsup ...

  8. Java_异常_04_ OutOfMemoryError系列

    二.参考资料 1.铁猫 OutOfMemoryError系列(1): Java heap space OutOfMemoryError系列(2): GC overhead limit exceeded ...

  9. Java企业微信开发_13_异常:com.qq.weixin.mp.aes.AesException: 解密后得到的buffer非法

    一.异常信息 方法:POST@ echostr是否存在 :false java.lang.IllegalArgumentException: 20 > -367029533 at java.ut ...

随机推荐

  1. CTFcracktools——非常实用的CTF解密工具

    做bugku的crypto题时偶然发现了这个,吐血推荐!! 十分全面好用 整合了常见的解码.进制转换等CTF常用的工具: 下载地址: https://github.com/0Linchen/CTFCr ...

  2. [模板] 容斥原理: 二项式反演 / Stirling 反演 / min-max 容斥 / 子集反演 / 莫比乌斯反演

    //待更qwq 反演原理 二项式反演 若 \[g_i=\sum_{j=1}^i {\binom ij} f_j\] , 则有 \[ f_i=\sum_{j=1}^i (-1)^{i-j} {i \ch ...

  3. 实习初步认识_1:部署renren-fast v2.0遇到的问题及解决方案

    部署renren-fast v2.0可参考官方文档https://www.renren.io/guide/#fornt(注意红色部分) 部署后台时一切正常,一下是官方文档内容: 2.1.后端部署 环境 ...

  4. 2019年11个javascript机器学习库

    Credits: aijs.rocks 虽然python或r编程语言有一个相对容易的学习曲线,但是Web开发人员更喜欢在他们舒适的javascript区域内做事情.目前来看,node.js已经开始向每 ...

  5. 「洛谷3338」「ZJOI2014」力【FFT】

    题目链接 [BZOJ] [洛谷] 题解 首先我们需要对这个式子进行化简,否则对着这么大一坨东西只能暴力... \[F_i=\sum_{j<i} \frac{q_iq_j}{(i-j)^2}-\s ...

  6. 【dp】友好城市

    题目一: [题目描述] Palmia国有一条横贯东西的大河,河有笔直的南北两岸,岸上各有位置各不相同的N个城市.北岸的每个城市有且仅有一个友好城市在南岸,而且不同城市的友好城市不相同. 每对友好城市都 ...

  7. MATLAB模型预测控制(MPC,Model Predictive Control)

    模型预测控制是一种基于模型的闭环优化控制策略. 预测控制算法的三要素:内部(预测)模型.参考轨迹.控制算法.现在一般则更清楚地表述为内部(预测)模型.滚动优化.反馈控制. 大量的预测控制权威性文献都无 ...

  8. Vim内直接使用p粘贴系统剪切板

    解决方法 set clipboard=unnamed

  9. 简单的makefile

    单一程序 准备一个hello.c #include <stdio.h> int main(void) { printf("Hello World!\n"); } gcc ...

  10. 支付宝aar添加与友盟冲突解决

    Program type already present: com.ta.utdid2.b.a.e" 错误提示: 删掉libs中utdid的jar.