有没有办法确定OOPS在jvm进程中所采用的大小

时间:2015-12-24 07:23:56

标签: java performance jvm

我正在调整在64位环境中运行的堆重Java应用程序(所需的堆大小超过32G),并打算将Xmx增加到适当的数量。

在32G之后,不会使用-XX:+ UseCompressedOops选项压缩OOP(普通对象指针)。因此,需要知道我的应用程序中OOP的确切大小,以补偿未压缩的OOPS并增加所需的额外内存。

有没有办法确定OOP单独消耗的总内存量?

1 个答案:

答案 0 :(得分:1)

在Maven Central上使用Java Object Layoutavailable非常简单。只需检查org.openjdk.jol.util.VMSupport.OOP_SIZE静态字段:

import org.openjdk.jol.util.VMSupport;

public class Test {
    public static void main(String[] args) {
        // Prints OOP size in bytes: usually 4 or 8
        System.out.println(VMSupport.OOP_SIZE);
    }
}

示例输出:

$ java -cp jol-core-0.4.jar;bin -Xmx32G Test
8

$ java -cp jol-core-0.4.jar;bin -Xmx31G Test
4

$ java -cp jol-core-0.4.jar;bin -Xmx32G -XX:-UseCompressedOops Test
8