文章目录
12. String的特性
12.1 String的基本特性
-
String声明为final的,不可被继承
String s1 = "ILOVEYOU";//字面量的定义方式String s2 = new String("ILOVEYOU");
-
String实现了serializable接口:表示字符串是支持序列化的(跨进程传输数据)。实现了Comparable接口:表示string可以比较大小
-
String在jdk8及以前内部定义了final char[] value用于存储字符串数据。idk9时改为byte[]
-
String:代表不可变的字符序列。不可变性
- 当对字符串重新赋值时,需要重写指定内存区域赋值,不能使用原有的value进行赋值。
- 当对现有的字符串进行连接操作时,也需要重新指定内存区域赋值,不能使用原有的value进行赋值。
- 当调用string的replace ()方法修改指定字符或字符串时,也需要重新指定内存区域赋值,不能使用原有的value进行赋值。
-
通过字面量的方式(区别于new)给一个字符串赋值,此时的字符串值声明在字符串常量池中。
字符串常量池中是不会存储相同内容的字符串的
12.1.1 StringTable
- string的string Pool是一个固定大小的Hashtable,默认值大小长度是1009。如果放进string Pool的string非常多,就会造成Hash冲突严重,从而导致链表会很长,而链表长了后直接会造成的影响就是当调用string.intern时性能会大幅下降。
- 使用
-XX:stringTablesize=?可设置stringTable的长度 - 在jdk6中stringTable是固定的,就是1009的长度,所以如果吊量池中的字符串过多就会导致效率下降很快。StringTablesize设置没有要求。
- 在jdk7中,stringTable的长度默认值是60013。
- jdk8开始,1009是StringTable可设置的最小值。
12.2 String的内存分配
- jdk6及以前字符串常量池存放在永久代中。jdk7将字符串常量池的位置调整到java堆中。jdk8字符串常量池在堆中。
12.3 字符串的拼接
-
常量与常量的拼接结果在常量池,原理是编译期优化
String s1 = "a" +"b" +"c";//等同于“abc”,在编译期间就赋值为“abc” String s2 = "abc"; System.out.println(s1 == s2);//true System.out.println(s1.equals(s2));//true -
常量池中不会存在相同内容的常量。
-
只要其中有一个是变量,结果就在堆中。变量拼接的原理是stringBuilder
-
如果拼接的结果调用intern()方法,则主动将常量池中还没有的字符串对象放入池中,并返回此对象地址。
String s1 = "javaEE"; String s2 = "hadoop"; String s3 = "javaEEhadoop"; String s4 = "javaEE" + "hadoop";//编译器优化 //如果拼接符号的前后出现了变量,则相当于在推空间中new String() String s5 = s1 + "hadoop"; String s6 = "javaEE"

本文详细探讨了Java中的String特性,包括其不可变性、内存分配、字符串拼接以及intern()方法的使用。讲解了字符串常量池在不同JDK版本的变化,并分析了new String()操作产生的对象数量。同时,强调了intern()方法在不同JDK版本的行为差异,对于理解和优化Java代码具有重要意义。
最低0.47元/天 解锁文章
1090

被折叠的 条评论
为什么被折叠?



