常量池 - 运行时常量池

常量池:

javap -verbose xxx

notice: xxx is a compiled class file

以上指令显示的:Constant pool 就是所谓的常量池,该内容的大小固定,在编译期就已经固。

存储的内容类似于:

#1 = Methodref
 #2 = Class
 #3 = Methodref
 #4 = Fieldref
 #5 = Methodref
 #6 = String
 #7 = Methodref
 #8 = String
 #9 = Class
#10 = InterfaceMethodref
#11 = Class
#12 = Methodref
#13 = Methodref

等等,具体可以查看 《深入java虚拟机》 6-3 图

运行时常量池

常量池在类加载以后会存入运行时常量池。运行期间也可以再增加常量置常量池。

java1.8 以后:

方法区移至Metaspace,字符串常量移至Java Heap

每一个类加载器的存储区域都称作一个元空间,所有的元空间合在一起就是我们一直说的元空间。当一个类加载器被垃圾回收器标记为不再存活,其对应的元空间会被回收。在元空间的回收过程中没有重定位和压缩等操作。但是元空间内的元数据会进行扫描来确定Java引用。 
元空间虚拟机负责元空间的分配,其采用的形式为组块分配。组块的大小因类加载器的类型而异。在元空间虚拟机中存在一个全局的空闲组块列表。当一个类加载器需要组块时,它就会从这个全局的组块列表中获取并维持一个自己的组块列表。当一个类加载器不再存活,那么其持有的组块将会被释放,并返回给全局组块列表。类加载器持有的组块又会被分成多个块,每一个块存储一个单元的元信息。组块中的块是线性分配(指针碰撞分配形式)。组块分配自内存映射区域。这些全局的虚拟内存映射区域以链表形式连接,一旦某个虚拟内存映射区域清空,这部分内存就会返回给操作系统。

(转:https://www.cnblogs.com/duanxz/p/3520829.html

猜你喜欢

转载自blog.csdn.net/u011385186/article/details/82991297
今日推荐