为什么要设计常量池?
字符串的分配,和其他的对象分配一样,耗费高昂的时间与空间代价,作为最基础的数据类型,大量频繁的创建字符串,极大程度地影响程序的性能
JVM为了提高性能和减少内存开销,在实例化字符串常量的时候进行了一些优化
为字符串开辟一个字符串常量池,类似于缓存区
创建字符串常量时,首先坚持字符串常量池是否存在该字符串
存在该字符串,返回引用实例,不存在,实例化该字符串并放入池中
存储过程
从JDK API的开发文档中我们发现
当
String对象被创建,和其他对象一样会先在栈 中创建一个对象的引用(用于存放地址),
但是并不直接在堆中存放字符串 数据,而是现在一块专门 叫做“常量池”的内存里面开辟一个空间内容为字符串的内容。
代码如下:
String str1 = “abc”;
String str2 = “abc”;
String str3 = “abc”;
String str4 = new String(“abc”);
String str5 = new String(“abc”);
前3行可以认为是直接将“abc”这个字符串常量的地址存在str1,str2,str3 中
而用new 方法创建的str对象则会在堆中创建对象的内容,而其中的值也是从常量池中来的。
所以测试代码:
这里还要插入一个编译期和运行期的概念
程序在编译期时会先在常量池中初始化所有常量,进入运行期时才会将栈和堆中的数据初始化。