说我有方法:
public String getString() {
char[] array = new char[]{'a', 'b', 'c'};
return new String(array);
}
数组是否仍然在String构造函数中复制,或者Java编译器是否足够智能以识别数组中的元素不能更改,因此它只能引用该数组?
由于
答案 0 :(得分:6)
由于java String
类是不可变,构造函数必须复制数组。
否则有人可以保留对数组的引用并对其进行修改:
char[] array = new char[]{'a', 'b', 'c'};
String string = new String(array);
array[1] = 'd'; // array modification must NOT affect the string
答案 1 :(得分:4)
查看java.lang.String
的来源:
/**
* Allocates a new {@code String} so that it represents the sequence of
* characters currently contained in the character array argument. The
* contents of the character array are copied; subsequent modification of
* the character array does not affect the newly created string.
*
* @param value
* The initial value of the string
*/
public String(char value[]) {
this.value = Arrays.copyOf(value, value.length);
}
修改强>:
另请参阅调用System.arraycopy
的{{3}}来源。
答案 2 :(得分:1)
答案应该是显而易见的:要使String
保持不变,它必须防御性地复制数组。
考虑以下代码:
public String getString() {
char[] array = new char[]{'a', 'b', 'c'};
String s = new String(array); // abc
array[0] = 'x';
return s; // xbc
}
如果阵列未复制,则支持阵列将泄露,使String暴露于可变性。
答案 3 :(得分:1)
看看这个构造函数:
153 public String(String original) {
154 this.value = original`.value;
155 this.hash = original.hash;
156 }
这将是一个字符串文字:
"abc"
这只是对String(char[] value)
的调用,其中a,b,c作为char数组的元素传入。简而言之,String x = "abc"
只是编译器为您提供的语法糖,可以解决您在上面所做的事情。
答案 4 :(得分:0)
如果您看到源代码,您将得到答案。输入数组被复制而不被引用。这是源代码:
public String(char value[]) {
this.offset = 0;
this.count = value.length;
this.value = StringValue.from(value);
}
static char[] from(char[] value) {
return Arrays.copyOf(value, value.length);
}