我正在调整在64位环境中运行的堆重Java应用程序(所需的堆大小超过32G),并打算将Xmx增加到适当的数量。
在32G之后,不会使用-XX:+ UseCompressedOops选项压缩OOP(普通对象指针)。因此,需要知道我的应用程序中OOP的确切大小,以补偿未压缩的OOPS并增加所需的额外内存。
有没有办法确定OOP单独消耗的总内存量?
答案 0 :(得分:1)
在Maven Central上使用Java Object Layout库available非常简单。只需检查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