1,(全局)字符串常量池(String Constant Pool)
1)使用
sun.jvm.hotspot.memory.StringTable类实现,extends Hashtable,使用线程安全的哈希表,在每个HotSpot VM实例中只有一份,被所有类共享
。
2)JDK1.6以及之前:字符串常量池放在方法区中,StringTable固定1009个,当字符串比较多的时候,会hash冲突,导致链表过长。
3)JDK1.7:字符串常量池移至堆中。StringTable长度可以不固定,使用JVM参数-XX:StringTableSize=66666设置。
3)存放比较:JDK1.6中存放的都是字符串常量
,JDK1.7中可以存放(位于堆中字符串对象的)引用,如使用String.intern()方法。
2,静态(class)常量池(Class Constant Pool)
1)每个class文件都有一个常量池。
image.png.class文件的类信息、字面量(字符串、整型值、final修饰的常量)、方法信息。
2)字面量Literal:文本字符串、8种基本类型的值、final常量
3)符号引用:类和方法的全限定名、字段名和描述符、方法名和描述符
3,运行时常量池(Runtime Constant Pool)
1)位于内存中,也就是
class常量池被加载到内存中
的版本。特点:字面量可以动态添加,比如String.intern(),符号引用可以解析成直接引用。
2)当Class加载到内存中,就会将class常量池
中的内容放到运行时常量池
中。每个类都有一个,在解析阶段,把符号引用替换为直接引用。直接引用也会放入常量池,避免下次再次解析。
3)解析过程中,当遇到字符串的符号引用,则回去查询常量池StringTable,以保证Runtime Constant Pool中的字符串与String Constant Pool中是一致的。
网友评论