JVM-内存指针压缩技术

JVM 在内存小于32GB的时候会采用一个内存对象指针压缩技术

在 Java 中,所有的对象都分配在堆上,并通过一个指针进行引用。 普通对象指针(OOP)指向这些对象,通常为CPU字长的大小:32 位或64 位,取决于你的处理器。指针引用的就是这个OOP值的字节位置。

对于32位的系统,意味着堆内存大小最大为4GB。对于64位的系统, 可以使用更大的内存,但是64位的指针意味着更大的浪费,因为你的指针本身大了。更糟糕的是, 更大的指针在主内存和各级缓存(例如LLC,L1等)之间移动数据的时候,会占用更多的带宽。

Java 使用一个叫作内存指针压缩(compressed oops)的技术来解决这个问题。 它的指针不再表示对象在内存中的精确位置,而是表示偏移量。这意味着32位的指针可以引用40亿个对象, 而不是40亿个字节。最终, 也就是说堆内存增长到32GB的物理内存,也可以用32位的指针表示。

一旦你越过那个神奇的~32GB的边界,指针就会切回普通对象的指针。 每个对象的指针都变长了,就会使用更多的CPU内存带宽,也就是说你实际上失去了更多的内存。事实上,当内存到达40~50GB 的时候,有效内存才相当于使用内存对象指针压缩技术时候的32GB内存。

即便你有足够的内存,也尽量不要超过32GB。因为它浪费了内存,降低了CPU的性能,还要让GC应对大内存。

那到底需要低于32GB多少来设置JVM呢?这需要看情况,确切的划分要根据JVMs和操作系统而定。 如果你想保证其安全可靠,设置堆内存为31GB是一个安全的选择。 另外,你可以在你的JVM设置里添加-XX:+PrintFlagsFinal用来验证JVM的临界值, 并且检查 UseCompressedOops的值是否为true。对于你自己使用的JVM和操作系统,这将找到最合适的堆内存临界值。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
优化JVM内存模型可以提高Java程序的性能和效率,具体优化方法如下: 1. 增加堆内存:通过增加堆内存大小,可以减少频繁的垃圾回收,从而提高程序的性能。可以通过设置JVM参数来增加堆内存大小,例如使用-Xmx参数设置最大堆内存大小。 2. 减少对象创建:对象的创建占用内存资源,频繁的对象创建也导致垃圾回收的频繁执行。因此,可以通过对象池等技术来减少对象创建,提高程序的性能。 3. 使用局部变量:将变量定义为局部变量可以有效地减少内存占用,从而提高程序的性能。可以尽量将变量定义为局部变量,避免定义为全局变量或者成员变量。 4. 避免内存泄漏:内存泄漏是指程序中的对象无法被垃圾回收器回收,最终导致内存溢出。因此,需要避免内存泄漏的情况出现,例如及时释放不再使用的对象等。 5. 使用垃圾收集器:使用合适的垃圾收集器可以提高程序的性能和效率。例如,CMS垃圾收集器适用于低延迟、高并发的场景,而G1垃圾收集器则适用于大内存、高吞吐量的场景。 6. 使用压缩指针:在64位JVM中,由于指针大小为8字节,占用更多的内存空间。因此,可以使用压缩指针技术来减少指针大小,从而减少内存占用。 举例来说,如果一个程序中频繁创建大量对象,可以使用对象池等技术来减少对象创建;如果程序中存在内存泄漏的情况,可以通过分析代码找出内存泄漏的原因,并及时释放不再使用的对象等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值