JVM优化之压缩普通对象指针(CompressedOops)

一般64位JVM消耗的内存会比32位的大1.5倍,这是由于对象指针在64位架构下,长度会翻倍(更宽的寻址)。 对于那些将要从32位平台移植到64位的应用来讲,平白无辜多了1/2的内存占用,这是开发者不肯意看到的。 幸运的是,从JDK 1.6 update14开始,64 bit JVM正式支持了 -XX:+UseCompressedOops 这个能够压缩指针,起到节约内存占用的新参数。数组

什么是 OOP ?

OOP = “ordinary object pointer” 普通对象指针。架构

启用CompressOops后,会压缩的对象: • 每一个Class的属性指针(静态成员变量) • 每一个对象的属性指针 • 普通对象数组的每一个元素指针ide

固然,压缩也不是万能的,针对一些特殊类型的指针,JVM是不会优化的。 好比指向PermGen的Class对象指针,本地变量,堆栈元素,入参,返回值,NULL指针不会被压缩。oop

CompressedOops的原理

原理,解释器在解释字节码时,植入压缩指令(不影响正常和JVM优化后的指令顺序)。 具体逻辑是,当对象被读取时,解压,存入heap时,压缩。优化

压缩指令伪码指针

! int R8; oop[] R9; // R9 is 64 bits ! oop R10 = R9[R8]; // R10 is 32 bits ! load compressed ptr from wide base ptr: movl R10, [R9 + R8<<3 + 16] ! klassOop R11 = R10._klass; // R11 is [...]对象

相关文章
相关标签/搜索