Exact state of committed memory in java

后端 未结 2 1127
清歌不尽
清歌不尽 2021-01-31 05:57

Im curious what the exact meaning of \"committed\" memory is when the value is queried from the MemoryUsage class. That class explains it as \"committed represents the amount o

2条回答
  •  北海茫月
    2021-01-31 06:39

    The committed size is the actually allocated memory, the used size is the size used for storing actual data (when used ~= committed it's time for major GC and possibly growing the heap). The Max size is the hard limit to which the heap can grow - if it's not enough the JVM throws OutOfMemoryError.

    If a memory is committed then it definitely can be used. Also, the only occasion when JVM would not be able to commit more memory (on a modern OS) is if the hardware is out of virtual memory.

    All these sizes only tell you the size of the heap region. The JVM has other memory regions as well (thread stacks, JIT cache, etc.) The heap region is usually largest, this roughly corresponds to the process footprint.

    Two notes:

    • if the committed size does not fit in the physical memory, parts of it will be swapped to the page file. This leads to big slowdown during GC and in such cases you will improve the app performance by reducing the heap size.
    • some operating systems allow double booking of memory - you can allocate as much as you want as long as you don't try to use it (forgot which OS it was - somebody fill me in)

提交回复
热议问题