==
tests for reference equality.
.equals()
tests for value equality.
Consequently, if you actually want to test whether two strings have the same value you should use .equals()
.
There are however a few situations where you can guarantee that two strings with the same value will be represented by the same object because of String interning. Those cases are specified by the Java Language Specification.
==
is for testing whether two strings are the same object.
// These two have the same valuenewString("test").equals("test")// --> true // ... but they are not the same objectnewString("test")=="test"// --> false // ... neither are thesenewString("test")==newString("test")// --> false // ... but these are because literals are interned by // the compiler and thus refer to the same object"test"=="test"// --> true // concatenation of string literals happens at compile time,// also resulting in the same object"test"=="te"+"st"// --> true// but .substring() is invoked at runtime, generating distinct objects"test"=="!test".substring(1)// --> false// interned strings can also be recalled by calling .intern()"test"=="!test".substring(1).intern()// --> true
It is important to note that ==
is a bit cheaper than equals()
(a single reference comparison instead of a method call), thus, in situations where it is applicable (i.e. you can guarantee that you are only dealing with interned strings) it can present an important performance improvement. However, these situations are rare.