String and Final
final
in this context means that the variable name
can only be assigned once. Assigning a different String
object to it again results in a compile error.
I think the source of the confusion here is that the final
keyword can be used in several different contexts:
- final class: The class cannot be subclassed.
- final method: The method cannot be overridden.
- final variable: The variable can only be assigned once.
See the Wikipedia article on final in Java for examples on each case.
Remember that Java final keyword serves two purposes in this case:
- it means the reference cannot be set to another String-- i.e. you cannot subsequently do "name = ...";
- but crucially, it means that the reference is correctly published to other threads (see linked article for more details, or works such as Goetz et al, "Java Concurrency in Practice".
"final" means different things in the two cases.
The java.lang.String class is final. This means you can't inherit from it.
The variable "name" is final, meaning that you can't change it to point to a different instance of String. So a non-final String variable isn't a constant, because you could read it at two different times and get different values.
As it happens, Java string objects are also immutable. This means that you cannot modify the value which a particular String object represents. Compare this with an array - you can replace the first element of an array object with a different object, but you can't replace the first character of a String object with a different char. This is why String.replace() returns a new string - it can't modify the old one.
One reason that String is final is to prevent an instance of a subclass of String, which implements mutable behaviour, being passed in place of a String.
But whether you can modify a particular object, and whether you can assign a different object to a variable, are completely different concepts. One is a property of String objects, and the other is a property of String variables, which are references to String objects.