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--

posted @   大墨垂杨  阅读(2922)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示