82

final因为我相信这是一种很好的编程习惯,所以如果打算只编写一次,我会制作所有(本地或实例)变量。

但是,我注意到,当变量赋值可能引发异常时,您不能将所述变量设为最终变量:

final int x;
try {
    x = Integer.parseInt("someinput");
}
catch(NumberFormatException e) {
    x = 42;  // Compiler error: The final local variable x may already have been assigned
}

有没有办法在不使用临时变量的情况下做到这一点?(或者这不是最终修饰符的正确位置吗?)

4

2 回答 2

74

一种方法是引入一个(非final)临时变量,但您说您不想这样做。

另一种方法是将代码的两个分支移动到一个函数中:

final int x = getValue();

private int getValue() {
  try {
    return Integer.parseInt("someinput");
  }
  catch(NumberFormatException e) {
    return 42;
  }
}

这是否实用取决于确切的用例。

总而言之,只要x是一个适当范围的局部变量,最实用的通用方法可能是将其保留为非final.

另一方面,如果x是成员变量,我的建议是final在初始化期间使用非临时变量:

public class C {
  private final int x;
  public C() {
    int x_val;
    try {
      x_val = Integer.parseInt("someinput");
    }
    catch(NumberFormatException e) {
      x_val = 42;
    }
    this.x = x_val;
  }
}
于 2012-11-28T11:38:30.637 回答
-1

不,这不是正确的地方,假设你在 try 和 catch 块中有超过 1 个语句,第一个语句说:x = 42。在其他一些语句之后,try 块失败,它转到 catch 块,你的说 x = 30。现在你定义了 x 两次。

于 2012-11-28T11:39:21.100 回答