Possible Duplicate:
Java Strings and StringPool
I created two Strings
String s1="MyString";
String s2=new String("MyString");
System.out.println(s1==s2);
it prints "false"
. we know that String pool doesn't create two Objects for same String literal.
Then what is happening here? It's creating two different String Objects(literals) in String pool for same String literal "MyString".
I know equals()
method returns true
here.
but when we use ==
it should compare two references and they should refer to the same
String Object in String constant pool.
Why It is not refering to the existing String object in the String pool even if it finds a match ?.
The first one goes to the pool while the second one is stored on the heap.
Use s2 = s2.intern();
to make it return true
.
When you do an intern()
on the string, the JVM ensures that the string is present in the pool. If it doesn't yet exist, it is created on the pool. Otherwise, the already existing instance is returned. I think this explains the ==
behaviour.
String s1="MyString";
String s2=new String("MyString");
s2 = s2.intern();
System.out.println(s1==s2);
As a reference, here is what the String.intern()
documentation says:
/**
* Returns a canonical representation for the string object.
* <p>
* A pool of strings, initially empty, is maintained privately by the
* class <code>String</code>.
* <p>
* When the intern method is invoked, if the pool already contains a
* string equal to this <code>String</code> object as determined by
* the {@link #equals(Object)} method, then the string from the pool is
* returned. Otherwise, this <code>String</code> object is added to the
* pool and a reference to this <code>String</code> object is returned.
* <p>
* It follows that for any two strings <code>s</code> and <code>t</code>,
* <code>s.intern() == t.intern()</code> is <code>true</code>
* if and only if <code>s.equals(t)</code> is <code>true</code>.
* <p>
* All literal strings and string-valued constant expressions are
* interned. String literals are defined in section 3.10.5 of the
* <cite>The Java™ Language Specification</cite>.
*
* @return a string that has the same contents as this string, but is
* guaranteed to be from a pool of unique strings.
*/
public native String intern();
In the line String s2=new String("MyString");
you are creating a new instance of String
, so it will surely won't be the same instance as s1
.
If you do:
System.out.println(s1=="MyString");
You will get true
.
s2
is NOT a string literal, it was constructed from one when using new
- but it is not a literal, it is a new object.
Actually you are creating two different objects one is in Literal Pool
and one is in Heap
String s1 = "MyString"; //literal pool
String s2 = new String("MyString"); //in heap
s.o.p(s1==s2); // false, because two different instances
s.o.p(s1.equals(s2)); // true, compares the contents of the string.
You need to use equals
instead ==
.
You can push the string objects from heap to String literal pool (or constant pool) by calling String.intern()
.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With