Java JNA包装器和内存消耗

问题描述 投票:1回答:1

我有一个问题,JVM处理JNA包装器如何显示内存消耗。

例如,我运行使用OpenCV JNA包装器的Java应用程序。 Java应用程序本身消耗1GB的RAM,而OpenCV本机库消耗3GB的RAM。总而言之,当我找到合适的Java JVM进程(通过ps命令)时,它将显示1GB的RAM或4GB(1 + 3)的RAM?

java memory memory-management jvm jna
1个回答
2
投票

您的ps输出将显示1GB的RSS(驻留集大小 - 分配给该进程并在RAM中的内存量。)Java进程不会直接显示使用的本机内存;但是,它将显示为VSZ的一部分(虚拟内存大小 - 进程可以访问的所有内存,包括已交换的内存,已分配但未使用的内存,以及来自共享库的内存。)

例如,我编写了以下代码:

import com.sun.jna.Memory;

public class TinyJavaBigC {
    public static void main(String[] args) {
        // Grab 1 GiB of memory
        Memory buf = new Memory(1 << 30);
        // Sleep long enough to grab ps
    }
}

无论使用new Memory(bytes)(有效地调用malloc)保留的本机内存量,Java应用程序在RSS中始终使用相同数量的内存,并且使用-Xmx限制Java堆大小并不会阻止超出此限制的本机内存分配。然而,1 GiB的本机内存显然从操作系统的“可用”内存中消失了。

我将上面的代码放在一个循环中,递增左移值以进行分配,然后使用-Xmx512m运行它,它应该具有有限的JVM堆到512 MiB。包含所有JVM堆栈和堆内存的RSS保持在~50 MiB范围内。分配的内存确实显示在与进程关联的VSZ中。因为这还包括其他类型的内存,它不是一个直接的衡量标准,并且大大超过了可用的RAM和交换文件大小限制,但它至少给出了增加分配的一些指示。

Native Memory          RSS          VSZ
       1 byte     42.0 MiB      9.6 GiB
      2 bytes     45.8 MiB      9.6 GiB
      4 bytes     46.0 MiB      9.6 GiB
      8 bytes     46.1 MiB      9.6 GiB
     16 bytes     46.3 MiB      9.6 GiB
     32 bytes     46.5 MiB      9.6 GiB
     64 bytes     47.0 MiB      9.6 GiB
    128 bytes     47.5 MiB      9.6 GiB
    256 bytes     47.6 MiB      9.6 GiB
    512 bytes     48.9 MiB      9.6 GiB
        1 KiB     49.1 MiB      9.6 GiB
        2 KiB     49.2 MiB      9.6 GiB
        4 KiB     49.3 MiB      9.6 GiB
        8 KiB     49.3 MiB      9.6 GiB
       16 KiB     49.8 MiB      9.6 GiB
       32 KiB     50.1 MiB      9.6 GiB
       64 KiB     50.1 MiB      9.6 GiB
      128 KiB     50.6 MiB      9.6 GiB
      256 KiB     51.4 MiB      9.6 GiB
      512 KiB     51.3 MiB      9.6 GiB
        1 MiB     51.4 MiB      9.6 GiB
        2 MiB     51.4 MiB      9.6 GiB
        4 MiB     51.4 MiB      9.6 GiB
        8 MiB     51.4 MiB      9.6 GiB
       16 MiB     51.3 MiB      9.7 GiB
       32 MiB     51.3 MiB      9.7 GiB
       64 MiB     51.7 MiB      9.8 GiB
      128 MiB     51.7 MiB      9.9 GiB
      256 MiB     51.6 MiB     10.1 GiB
      512 MiB     51.6 MiB     10.5 GiB
        1 GiB     51.7 MiB     11.3 GiB
        2 GiB     51.8 MiB     12.8 GiB
        4 GiB     51.9 MiB     15.8 GiB
        8 GiB     51.9 MiB     21.8 GiB
       16 GiB     52.0 MiB     33.8 GiB
       32 GiB     52.0 MiB     57.8 GiB
       64 GiB     52.1 MiB    105.8 GiB
      128 GiB     52.1 MiB    201.8 GiB
      256 GiB     52.5 MiB    393.8 GiB
      512 GiB     52.6 MiB    777.8 GiB
        1 TiB     52.7 MiB      1.5 TiB
        2 TiB     52.7 MiB      3.0 TiB
        4 TiB     52.8 MiB      6.0 TiB
        8 TiB     52.9 MiB     12.0 TiB
       16 TiB     53.1 MiB     24.0 TiB
       32 TiB     53.2 MiB     48.0 TiB
Exception in thread "main" java.lang.OutOfMemoryError: Cannot allocate 70368744177664 bytes
© www.soinside.com 2019 - 2024. All rights reserved.