开发者

Final variables as method arguments

I was looking at some code from a colleague and saw the following method:

public void someMethod(final String str) {
    ...
}

which I found odd, as Strings are immutable, anyway. I think it is safe to delete the final keyword, there.

I also found the following

public void reportProblems(final Collection<IProblem> problems) {
    ...
}
开发者_运维技巧

There aren't any inner classes around, so.. is there a point in using the final keyword there? It looks to me that having the final there is absolutely the same as not having. Am I right?

Thanks


The immutability of string is completely irrelevant to whether it's declared final or not. You could have a final StringBuilder parameter, and it would prevent exactly the same thing: reassignment of the variable within the method. You'd still be able to append to the StringBuilder. final in Java isn't the same as const in C++.

Some people like to make everything final when they can - if you know that the value of a variable doesn't change, it can be easier to reason about it. I have a lot of sympathy with that view, and often take the same approach myself - except that I don't actually force the issue with the final modifier, simply because it adds cruft in the code. If final were the default and you had to explicitly use a mutable modifier, I suspect that most developers wouldn't start making every local variable mutable... they'd just use the default most of the time, as they do now.

So, to come back to the original question: I suspect the developer just wants to be explicit about their style. It's not how I do it, but I can understand the motivation. Another possibility is that at one point there was an inner class, but that's gone now and the developer forgot to remove the final modifier.

Of course, if your colleague wrote the code, you don't have to guess - just ask!


It looks to me that having the final there is absolutely the same as not having. Am I right?

You are wrong in that it's not absolutely the same.

Code like below would compile without final...

public void someMethod(String str) {
    str = "nonsense"; // will compile fine
}

...and won't compile if there's final

public void someMethod(final String str) {
    str = "nonsense"; // won't compile
}

"What a difference a word makes"


It prevents you from assigning to parameter variable inside the method body. So it does make a difference.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜