I was asked this question:
String s = "abc"; // creates one String object and one
// reference variable
In this simple case, "abc" will go in the pool and s will refer to it.
String s = new String("abc"); // creates two objects,
// and one reference variable*
Based on above details how many String objects and how many reference variables were created prior to the println statement of below code?
String s1 = "spring ";
String s2 = s1 + "summer ";
s1.concat("fall ");
s2.concat(s1);
s1 += "winter ";
System.out.println(s1 + " " + s2);
My answer was The result of this code fragment is spring winter spring summer
There are two reference variables, s1 and s2. There were a total of eight String objects created as follows: "spring", "summer " (lost), "spring summer", "fall" (lost), "spring fall" (lost), "spring summer spring" (lost), "winter" (lost), "spring winter" (at this point "spring" is lost).
Only two of the eight String objects are not lost in this process.
Is it correct?
Answer is: 2 references and 8 objects.
String s1 = "spring "; //One reference and 1 object in string pool. (if it didn't exist already)
String s2 = s1 + "summer "; //Two references and 3 objects
s1.concat("fall "); //Two references and 5 objects
s2.concat(s1); //Two references and 6 objects
s1 += "winter "; //Two references and 8 objects
System.out.println(s1 + " " + s2);
Now your question: How does Java handle String objects in memory?
Java provides two ways to create object of class String
.
- String str1 = "OneString";
In this case, JVM searches the string pool to see if equivalent string exist already. if yes, returns the reference to same. if not, adds it to string pool and returns the reference. So a new object may be created OR may not be.
- String str1 = new String("OneString");
Now, JVM has to create an object on heap. due to new. it doesn't matter if OneString
is already present in string pool.
You can also put a string to pool:
You can call intern() on a String object. This will put the String object in the pool if it is not already there, and return the reference to the pooled string. (If it was already in the pool, it just returns a reference to the object that was already there).
You may like to look at following links:
What is the Java string pool and how is "s" different from new String("s")?
Strings in java are immutable. There is allocated character array, and some surrounding information like offset and length. In case you are using string literals to initialize your strings, compiler tries to optimize and will create only one string object for each literal - this is possible because they are immutable.
If you do concatenation or + on strings, then new string will be alloacted and data compied together (with performance penalty.
Contrary to this, creating substring out of string is virtually free - no data will be copied
String s = "abc"; // creates one String object and one
// reference variable
Creates one string object only if the object doesn't present on the String Constant Pool already.
String s = new String("abc"); // creates two objects,
// and one reference variable*
This actually creates only one object in the heap. It adds this object to pool if and only if the intern() method is called on this String object.
String s1 = "spring ";
String s2 = s1 + "summer ";
s1.concat("fall ");
s2.concat(s1);
s1 += "winter ";
System.out.println(s1 + " " + s2);
You explanation seems ok, except you have one more string in System.out.println().:-)
When you say (lost) it actually means that it is no more live object (reference is not present on the stack).
Looks correct. This is a SCJP exam question btw.
concat returns a new String, this is lost. The first s1 is overridden with "spring winter "
Two things you should know about Strings in Java:
- Strings are immutable (as already explained by you)
- Strings may reside in the String pool. Not every time you write "Summer" a completely new String ist constructed, the immutable "Summer" might come out of the pool (depends on the JVM, but for Oracle, it is). See also: http://docs.oracle.com/javase/1.4.2/docs/api/java/lang/String.html#intern()
Cheers Christian
来源:https://stackoverflow.com/questions/8998717/how-does-java-handle-string-objects-in-memory