MemoryUsage:监测java虚拟机内存使用

通过MemoryUsage可以查看Java 虚拟机的内存池的内存使用情况。MemoryUsage类有四个值(均以字节为单位):

===Init===

java虚拟机在启动的时候向操作系统请求的初始内存容量。

java虚拟机在运行的过程中可能向操作系统请求更多的内存或将内存释放给操作系统,所以init的值是不确定的。

===Used===

当前已经使用的内存量。

===Committed===

表示保证java虚拟机能使用的内存量,已提交的内存量可以随时间而变化(增加或减少)。

Java 虚拟机可能会将内存释放给系统,committed 可以小于 init。committed 将始终大于或等于 used。

===Max===

表示可以用于内存管理的最大内存量(以字节为单位)。

可以不定义其值,如果定义了该值,最大内存量可能随时间而更改。

已使用的内存量和已提交的内存量将始终小于或等于 max(如果定义了 max)。

如果内存分配试图增加满足以下条件的已使用内存将会失败:used > committed,即使 used <= max 仍然为 true(例如,当系统的虚拟内存不足时)。

可以通过一下diamante,随时监测java虚拟机内存使用情况:

package tools;

import java.lang.management.ManagementFactory;
import java.lang.management.MemoryUsage;
import java.util.Scanner;

public class memory_usage {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        while (true) {
            System.out.println("input enter to continue, input other to break.");
            String s = in.nextLine();
            if (!s.equals("")){
                break;
            }

            MemoryUsage mu = ManagementFactory.getMemoryMXBean().getHeapMemoryUsage();

            long getCommitted = mu.getCommitted();
            long getInit = mu.getInit();
            long getUsed = mu.getUsed();
            long max = mu.getMax();

            System.out.println("===================================<br/>");
            System.out.println(">>getCommitted(byte)>>" + getCommitted + "<br/>");
            System.out.println(">>getInit(byte)>>" + getInit + "<br/>");
            System.out.println(">>getUsed(byte)>>" + getUsed + "<br/>");
            System.out.println(">>max(byte)>>" + max + "<br/>");

            System.out.println("===================================<br/>");
            System.out.println(">>getCommitted(KB)>>" + getCommitted / 1000 + "<br/>");
            System.out.println(">>getInit(KB)>>" + getInit / 1000 + "<br/>");
            System.out.println(">>getUsed(KB)>>" + getUsed / 1000 + "<br/>");
            System.out.println(">>max(KB)>>" + max / 1000 + "<br/>");

            System.out.println("===================================<br/>");
            System.out.println(">>getCommitted(MB)>>" + getCommitted / 1000 / 1000 + "<br/>");
            System.out.println(">>getInit(MB)>>" + getInit / 1000 / 1000 + "<br/>");
            System.out.println(">>getUsed(MB)>>" + getUsed / 1000 / 1000 + "<br/>");
            System.out.println(">>max(MB)>>" + max / 1000 / 1000 + "<br/>");
        }

        System.out.println("====end====");
    }
}

--End--

原文地址:https://www.cnblogs.com/quchunhui/p/7609967.html