捕获异常时是否有理由不使用final关键字?

马修 :

在某些示例BlackBerry Java类中,我已经看到以下代码:

try
{
    // stuff that will throw an exception
}
catch(final Exception e)
{
    // deal with it
}

我认为这final是为了表现。按照标题,由于几乎没有(曾经?)有任何理由修改Exception已经抛出的,它们应该总是final吗?

如果是这样,编译器是否可以完成此操作?还是由编译器完成,final手动添加完全没有影响?

亚述:

Java语言规范11.2.2在最终异常与非最终异常之间进行了区别:

如果throw语句(第14.18节)的抛出表达式具有静态类型E,并且不是最终或有效的final异常参数,则可以抛出E或抛出表达式可以抛出的任何异常类。
[...]
如果throw语句的抛出表达式是catch子句C的最终或有效的最终异常参数,则可以抛出异常类E iff:

  • E是一个异常类,声明C的try语句的try块可以抛出该异常类;
  • E是与C的任何可捕获异常类兼容的分配;
  • E与在同一try语句中C左侧声明的catch子句的任何可捕获异常类的分配都不兼容。

有趣的是,JLS 14.20还说:

在uni-catch子句中,未声明为final(隐式或显式)的异常参数如果从未在其范围内作为赋值运算符的左侧操作数出现,则实际上被认为是final。

换句话说,如果您不重新分配ecatch语句(如e = new SomeOtherException();),则将其隐式声明为final。

因此,我只能得出结论,这没有什么区别,除非在catch块中修改了异常,并且我能想到的唯一示例是:

public void method1() throws IOException {
    try {
        throw new IOException();
    } catch (Exception e) { // e is not modified in catch => implicitly final
        throw e; //compiles OK
    }
}

//it works because method1 is semantically equivalent to method2:
public void method2() throws IOException {
    try {
        throw new IOException();
    } catch (final Exception e) {
        throw e;
    }
}

public void method3() throws IOException {
    try {
        throw new IOException("1");
    } catch (Exception e) {
        e = new IOException("2"); //e modified: not implicitly final any more
        throw e; //does not compile
    }
}

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

是否有理由在类型和接口前面使用clarify关键字?

来自分类Dev

是否有理由不使用最新的C ++标准?

来自分类Dev

是否有理由不使用自定义的“评论”属性?

来自分类Java

读取所有字符时,是否有理由在InputStreamReader上使用BufferedReader?

来自分类Dev

除了速度之外,是否有理由在=。上使用==?

来自分类Dev

是否有理由在日期参数中使用\ +或\-?

来自分类Dev

当仅需单个组件中的数据时,是否有理由使用Redux存储?

来自分类Dev

是否有理由在迭代和绘制字典或数组时使用pyglet批处理?

来自分类Dev

是否有理由不使用EnumPassthru = true声明所有protobuf-net ProtoContract属性类

来自分类Dev

有没有理由在编写火花作业时不使用SparkContext.getOrCreate?

来自分类Dev

在使用 python 多处理时使用 pool.map 时是否有理由调用 join ?

来自分类Dev

有没有理由在不使用-f的情况下使用git clean?

来自分类Dev

有没有理由不使用链接时间优化(LTO)的原因?

来自分类Dev

是否有理由选择发件人:在Swift中创建@IBAction时是否可以?

来自分类Dev

当我执行计算时,MATLAB 是否有理由给我偏差?

来自分类Dev

在Rails中调用辅助方法时,是否有理由不包含模块名称?

来自分类Dev

如果您已经在使用.onSnapshot,是否有理由使用AngularFire订阅Firebase?

来自分类Dev

是否有理由引用退出状态$?多变的?

来自分类Dev

是否有理由引用退出状态$?多变的?

来自分类Dev

是否有理由编写.eqv。。真正。?

来自分类Dev

是否有理由在C ++中向前声明main

来自分类Dev

`EINTR`:其背后是否有理由?

来自分类Dev

标准算法是否有理由重视Lambda?

来自分类Dev

是否有理由保留SVN分支?

来自分类Dev

是否有理由禁用N键翻转?

来自分类Dev

是否有理由在VERSION语句之前放置@static?

来自分类Dev

是否有理由能够在.format内部声明变量?

来自分类Dev

是否有理由使用“ [!-f文件] ||命令”而不是“ [-f文件] &&命令”?

来自分类Java

是否有理由不在Android Studio中使用Lombok

Related 相关文章

  1. 1

    是否有理由在类型和接口前面使用clarify关键字?

  2. 2

    是否有理由不使用最新的C ++标准?

  3. 3

    是否有理由不使用自定义的“评论”属性?

  4. 4

    读取所有字符时,是否有理由在InputStreamReader上使用BufferedReader?

  5. 5

    除了速度之外,是否有理由在=。上使用==?

  6. 6

    是否有理由在日期参数中使用\ +或\-?

  7. 7

    当仅需单个组件中的数据时,是否有理由使用Redux存储?

  8. 8

    是否有理由在迭代和绘制字典或数组时使用pyglet批处理?

  9. 9

    是否有理由不使用EnumPassthru = true声明所有protobuf-net ProtoContract属性类

  10. 10

    有没有理由在编写火花作业时不使用SparkContext.getOrCreate?

  11. 11

    在使用 python 多处理时使用 pool.map 时是否有理由调用 join ?

  12. 12

    有没有理由在不使用-f的情况下使用git clean?

  13. 13

    有没有理由不使用链接时间优化(LTO)的原因?

  14. 14

    是否有理由选择发件人:在Swift中创建@IBAction时是否可以?

  15. 15

    当我执行计算时,MATLAB 是否有理由给我偏差?

  16. 16

    在Rails中调用辅助方法时,是否有理由不包含模块名称?

  17. 17

    如果您已经在使用.onSnapshot,是否有理由使用AngularFire订阅Firebase?

  18. 18

    是否有理由引用退出状态$?多变的?

  19. 19

    是否有理由引用退出状态$?多变的?

  20. 20

    是否有理由编写.eqv。。真正。?

  21. 21

    是否有理由在C ++中向前声明main

  22. 22

    `EINTR`:其背后是否有理由?

  23. 23

    标准算法是否有理由重视Lambda?

  24. 24

    是否有理由保留SVN分支?

  25. 25

    是否有理由禁用N键翻转?

  26. 26

    是否有理由在VERSION语句之前放置@static?

  27. 27

    是否有理由能够在.format内部声明变量?

  28. 28

    是否有理由使用“ [!-f文件] ||命令”而不是“ [-f文件] &&命令”?

  29. 29

    是否有理由不在Android Studio中使用Lombok

热门标签

归档