最不常见的java异常_【Java】译文《最常见的10种Java异常问题》

首页

专栏

java

文章详情

2

109472.html

译文《最常见的10种Java异常问题》

109472.html潘潘和他的朋友们发布于 今天 01:01

be72cc178337b50935ca54c921dd0162.png

4038aed2cfd5b7281978f63e84c27218.png

知彼知己,方能百战不殆。

前言

本文总结了有关Java异常的十大常见问题。

目录

检查型异常(checked) vs. 非检查型异常(Unchecked)

异常管理的最佳实践箴言

为什么在try代码块中声明的变量不能在catch或者finally中被引用?

为什么 Double.parseDouble(null) 和 Integer.parseInt(null) 抛出的异常不一样呢?

Java中经常使用的运行时异常

我们可以在同一个catch子句中捕获多个异常吗?

在 Java 中构造方法能抛出异常吗?

在 final 代码块中抛出异常

try语句有return那么finally还会执行吗?

为何有些开发人员对异常置之不理?

d8db87d2784951fe4d7bf6e2d68f5bde.png

检查型异常(checked) vs. 非检查型异常(Unchecked)

例如,IOException就是常见的检查型异常,而 RuntimeException(运行时异常)就是非检查型异常。在阅读剩余部分之前你或许可以研读这份 Java异常的层次结构图。

913b57e4d64802cb1bb313a1dd92cf1a.png

39cd50d81ef2d266082cacde9be31180.png

异常管理的最佳实践箴言

如果可以正确处理异常,则应将其捕获并处理,否则应将其抛出。

7f2dacc4418c9da7b425d0eea9de861e.png

为什么在try代码块中声明的变量不能在catch或者finally中被引用?

看下面这段代码,在try代码块中声明的 String s 就不能在catch中被引用, 这段代码在编译期是通不过的。

try {

File file = new File("path");

FileInputStream fis = new FileInputStream(file);

String s = "inside";

} catch (FileNotFoundException e) {

e.printStackTrace();

System.out.println(s);

}

原因是你不知道在try代码块中哪个位置会引发异常, 很有可能在声明对象之前就引发了异常。对于这个特定的示例,是正确的。

4092268a65828ae99a89caba6911e64f.png

为什么 Double.parseDouble(null) 和 Integer.parseInt(null) 抛出的异常不一样呢?

它俩抛出的异常确实不同,但这是JDK的问题,当时开发这两个接口的开发人员不是同一波,所以我们没必要去纠结这个问题。

Integer.parseInt(null);

// throws java.lang.NumberFormatException: null

Double.parseDouble(null);

// throws java.lang.NullPointerException

a1dd30a35a34c9f62b04a358e1ab9af4.png

Java中经常使用的运行时异常

这里列举一部分:

在有些场景某个目标对象不满足我们的预期,会用到这些异常,例如下面在 if 判断语句中被使用:

if (obj == null) {

throw new IllegalArgumentException("obj can not be null");

b062e7841f42c1838721d8cb7c450d6b.png

我们可以在同一个catch子句中捕获多个异常吗?

答案是当然可以,不过如果在同一个catch子句中捕获的这些异常都直接或间接继承自同一父类,那么就只能在catch子句中捕获父类了。

// Java 7 之前需要这样

catch (AException a) {

logger.error(a);

throw new MyException("a");

catch (BException b) {

logger.error(b);

throw new MyException("b");

}catch (CException c) {

logger.error(c);

throw new MyException("c");

}

// 在Java 7中,可以捕获所有这些异常

catch(AException | BException | CException ex){

logger.error(ex);

throw new MyException(ex);

}

452287fb9839288b662dc7817ad064b3.png

在 Java 中构造方法能抛出异常吗?

答案是当然可以,构造方法仅是一种特殊方法而已。可以参考这个示例。

755222627c3c9af71d22c45bfc9f3d0d.png

在 final 代码块中抛出异常

下面这个写法是合法的:

public static void main(String[] args) {

File file1 = new File("path1");

File file2 = new File("path2");

try {

FileInputStream fis = new FileInputStream(file1);

} catch (FileNotFoundException e) {

e.printStackTrace();

} finally {

try {

FileInputStream fis = new FileInputStream(file2);

} catch (FileNotFoundException e) {

e.printStackTrace();

}

}

}

但是为了获得更好的代码可读性,你应该将把 try-catch代码块封装成一个新方法,然后将方法调用放在finally子句中:

public static void main(String[] args) {

File file1 = new File("path1");

File file2 = new File("path2");

try {

FileInputStream fis = new FileInputStream(file1);

} catch (FileNotFoundException e) {

e.printStackTrace();

} finally {

// 封装方法

methodThrowException();

}

}

a626d7834ce370301f44d14b097398fa.png

try语句有return那么finally还会执行吗?

答案是肯定会执行。

意思就是 ” 只要存在try代码块,finally代码块就一定会执行 ” ,这种特性可以让程序员避免在try语句中使用return, continue或者break关键字而忽略了关闭相关资源的操作等。

451fd36f1cf6490290ed6c9523d3219a.png

为何有些开发人员对异常置之不理?

很多时候会见到下面这种代码写法。允许的情况下尽可能捕获异常并且进行处理,不知道为什么很多开发人员就是这么干?

try {

...

} catch(Exception e) {

e.printStackTrace();

}

忽略异常是一件很容易做到的事,虽然这种写法很常见,但不一定是正确的写法。

参考文献:

Unchecked exceptions in Java

The root of Java exception class hierarchy

Java exceptions related questions in stackoverflow

7e833d50bab9be00359c4a14578d741c.png

782a7300b02c1a576ffa04886826cd77.png

java程序员异常exception翻译

本文系翻译,阅读原文

https://www.programcreek.com/2013/10/top-10-questions-about-java-exceptions/

阅读 40发布于 今天 01:01

赞2收藏

分享

109472.html

潘潘和他的朋友们

有点特别的架构师

1声望

2粉丝

关注作者

0 条评论

得票时间

109472.html

提交评论

109472.html

潘潘和他的朋友们

有点特别的架构师

1声望

2粉丝

关注作者

宣传栏

be72cc178337b50935ca54c921dd0162.png

4038aed2cfd5b7281978f63e84c27218.png

知彼知己,方能百战不殆。

前言

本文总结了有关Java异常的十大常见问题。

目录

检查型异常(checked) vs. 非检查型异常(Unchecked)

异常管理的最佳实践箴言

为什么在try代码块中声明的变量不能在catch或者finally中被引用?

为什么 Double.parseDouble(null) 和 Integer.parseInt(null) 抛出的异常不一样呢?

Java中经常使用的运行时异常

我们可以在同一个catch子句中捕获多个异常吗?

在 Java 中构造方法能抛出异常吗?

在 final 代码块中抛出异常

try语句有return那么finally还会执行吗?

为何有些开发人员对异常置之不理?

d8db87d2784951fe4d7bf6e2d68f5bde.png

检查型异常(checked) vs. 非检查型异常(Unchecked)

例如,IOException就是常见的检查型异常,而 RuntimeException(运行时异常)就是非检查型异常。在阅读剩余部分之前你或许可以研读这份 Java异常的层次结构图。

913b57e4d64802cb1bb313a1dd92cf1a.png

39cd50d81ef2d266082cacde9be31180.png

异常管理的最佳实践箴言

如果可以正确处理异常,则应将其捕获并处理,否则应将其抛出。

7f2dacc4418c9da7b425d0eea9de861e.png

为什么在try代码块中声明的变量不能在catch或者finally中被引用?

看下面这段代码,在try代码块中声明的 String s 就不能在catch中被引用, 这段代码在编译期是通不过的。

try {

File file = new File("path");

FileInputStream fis = new FileInputStream(file);

String s = "inside";

} catch (FileNotFoundException e) {

e.printStackTrace();

System.out.println(s);

}

原因是你不知道在try代码块中哪个位置会引发异常, 很有可能在声明对象之前就引发了异常。对于这个特定的示例,是正确的。

4092268a65828ae99a89caba6911e64f.png

为什么 Double.parseDouble(null) 和 Integer.parseInt(null) 抛出的异常不一样呢?

它俩抛出的异常确实不同,但这是JDK的问题,当时开发这两个接口的开发人员不是同一波,所以我们没必要去纠结这个问题。

Integer.parseInt(null);

// throws java.lang.NumberFormatException: null

Double.parseDouble(null);

// throws java.lang.NullPointerException

a1dd30a35a34c9f62b04a358e1ab9af4.png

Java中经常使用的运行时异常

这里列举一部分:

在有些场景某个目标对象不满足我们的预期,会用到这些异常,例如下面在 if 判断语句中被使用:

if (obj == null) {

throw new IllegalArgumentException("obj can not be null");

b062e7841f42c1838721d8cb7c450d6b.png

我们可以在同一个catch子句中捕获多个异常吗?

答案是当然可以,不过如果在同一个catch子句中捕获的这些异常都直接或间接继承自同一父类,那么就只能在catch子句中捕获父类了。

// Java 7 之前需要这样

catch (AException a) {

logger.error(a);

throw new MyException("a");

catch (BException b) {

logger.error(b);

throw new MyException("b");

}catch (CException c) {

logger.error(c);

throw new MyException("c");

}

// 在Java 7中,可以捕获所有这些异常

catch(AException | BException | CException ex){

logger.error(ex);

throw new MyException(ex);

}

452287fb9839288b662dc7817ad064b3.png

在 Java 中构造方法能抛出异常吗?

答案是当然可以,构造方法仅是一种特殊方法而已。可以参考这个示例。

755222627c3c9af71d22c45bfc9f3d0d.png

在 final 代码块中抛出异常

下面这个写法是合法的:

public static void main(String[] args) {

File file1 = new File("path1");

File file2 = new File("path2");

try {

FileInputStream fis = new FileInputStream(file1);

} catch (FileNotFoundException e) {

e.printStackTrace();

} finally {

try {

FileInputStream fis = new FileInputStream(file2);

} catch (FileNotFoundException e) {

e.printStackTrace();

}

}

}

但是为了获得更好的代码可读性,你应该将把 try-catch代码块封装成一个新方法,然后将方法调用放在finally子句中:

public static void main(String[] args) {

File file1 = new File("path1");

File file2 = new File("path2");

try {

FileInputStream fis = new FileInputStream(file1);

} catch (FileNotFoundException e) {

e.printStackTrace();

} finally {

// 封装方法

methodThrowException();

}

}

a626d7834ce370301f44d14b097398fa.png

try语句有return那么finally还会执行吗?

答案是肯定会执行。

意思就是 ” 只要存在try代码块,finally代码块就一定会执行 ” ,这种特性可以让程序员避免在try语句中使用return, continue或者break关键字而忽略了关闭相关资源的操作等。

451fd36f1cf6490290ed6c9523d3219a.png

为何有些开发人员对异常置之不理?

很多时候会见到下面这种代码写法。允许的情况下尽可能捕获异常并且进行处理,不知道为什么很多开发人员就是这么干?

try {

...

} catch(Exception e) {

e.printStackTrace();

}

忽略异常是一件很容易做到的事,虽然这种写法很常见,但不一定是正确的写法。

参考文献:

Unchecked exceptions in Java

The root of Java exception class hierarchy

Java exceptions related questions in stackoverflow

7e833d50bab9be00359c4a14578d741c.png

782a7300b02c1a576ffa04886826cd77.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值