Exception疑问及解答
- 在方法中throw 异常,一定在方法上声明吗?什么场景下不需要声明
这个问题出现的问题是,我实现的一个方法是耗时操作,所以限制在UI主线程中操作,避免出现ANR,所以在方法中,如果判断当前是主线程,则直接抛出IllegalThreadStateException,但是review 代码的时候,Commiter 要求我在方法声明的后面加上throws IllegalThreadStateException的声明,所以我重新分析和验证了下其中的必要性,结果是:不必要
if (Looper.getMainLooper() == Looper.myLooper()) {
throw new IllegalThreadStateException("not support executor in MainThred");
}
原因如下:
- 我抛出的是unChecked的异常,即使是在方法增加了throws声明,也不要强制要求调用方去处理(那基本等于调用方不会主动去处理)
- 而且Java 规范也没有要求throw uncheckedException 需要在方法上声明,没有要求就没有必要多次一举
额外说明 - unChecked异常本来就不建议去捕获处理,因为这个就是应该在coding 过程中避免的。直接抛出来反而要求coder避免在主线程中调用此方法。
- 被调用方法抛出异常,调用者一定要进行处理吗?处理方法有哪些?
- checkedException 在方法中throw XXXException 抛出的话是一定要在方法中通过 throws XXXException 声明的,并且调用方也必要处理。但是unCheckException 调用者不一定要主动去处理,即使主动去处理也无法将程序恢复,并且应该在coding 过程中主要去避免这类异常的出现。比如我们常见的outOfIndexException、nullException
- 处理方法一般有两法,一种是抛给上层调用者去处理,二是自己捕获去处理
- 如何区分unCheckException 和checkedException?
- 我们可以从Exception的继承关系上说明如何区分未受检异常和受检异常:继承自RuntimeException 的异常是unCheckedException,是应该避免出现并且不需要主动处理的,其他的则是CheckException,需要调用方主动去处理的。比如IOException

参考资料
https://blog.youkuaiyun.com/hhy62011980/article/details/5548278
本文探讨了在Java中是否必须在方法上声明throw的异常,特别是对于未检查异常(Unchecked Exception)如IllegalThreadStateException。作者指出,由于这种异常是运行时异常,不需要在方法声明中强制处理,调用方可以选择捕获或不捕获。文章强调了未检查异常应尽量避免,抛出此类异常有助于提示开发者避免在主线程中进行耗时操作。此外,还解释了checked异常与unchecked异常的区别,并提供了处理异常的两种方式:向上抛出或在当前方法内处理。

被折叠的 条评论
为什么被折叠?



