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--
MemoryUsage:监测java虚拟机内存使用的更多相关文章
- Java虚拟机内存模型及垃圾回收监控调优
Java虚拟机内存模型及垃圾回收监控调优 如果你想理解Java垃圾回收如果工作,那么理解JVM的内存模型就显的非常重要.今天我们就来看看JVM内存的各不同部分及如果监控和实现垃圾回收调优. JVM内存 ...
- 如何设置Java虚拟机内存以适应大程序的装载
Java虚拟机对于运行时的程序所占内存是有限制的,当我们的项目或者程序很大时,往往会照成内存溢出. 举个例子: public class SmallTest1 { public static void ...
- 打包apk java 虚拟机内存不足
解决方案:在android->sdk->build-tools-android-version 中有个 dx.bat dx.bat --dex 命令的dx.bat脚本有这样一句代码 REM ...
- Java虚拟机-内存tips
java虚拟机内存可以分为独占区和共享区. 独占区:虚拟内存栈.本地方法栈.程序计数器. 共享区:方法区.Java堆(用来存放对象实例). 程序计数器 比较小的内存空间,当前线程所执行的字节码的行号指 ...
- Java虚拟机内存溢出异常--《深入理解Java虚拟机》学习笔记及个人理解(三)
Java虚拟机内存溢出异常--<深入理解Java虚拟机>学习笔记及个人理解(三) 书上P39 1. 堆内存溢出 不断地创建对象, 而且保证创建的这些对象不会被回收即可(让GC Root可达 ...
- JVM基础系列第6讲:Java 虚拟机内存结构
看到这里,我相信大家对于一个 Java 源文件是如何变成字节码文件,以及字节码文件的含义已经非常清楚了.那么接下来就是让 Java 虚拟机运行字节码文件,从而得出我们最终想要的结果了.在这个过程中,J ...
- java虚拟机内存不足,“Could not create the Java Virtual Machine”问题解决方案
java虚拟机内存不足,"Could not create the Java Virtual Machine"问题解决方案 在运行java程序时,遇到问题"Could n ...
- 总结Java虚拟机内存区域模型
本篇文章主要来总结一下Java虚拟机内存的各个区域,以及这些区域的作用.服务对象以及其中可能产生的问题,作为大家的面试宝典. 首先我们来看一下Java运行时的数据区域,Java虚拟机在执行Java程序 ...
- Java虚拟机内存分配详解
简介 了解Java虚拟机内存分布的好处 1.了解Java内存管理的细节,有助于程序员编写出性能更好的程序.比如,在新的线程创建时,JVM会为每个线程创建一个专属的栈 (stack),其栈是先进后出的数 ...
随机推荐
- 操作系统-百科:Linux
ylbtech-操作系统-百科:Linux Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和UNIX的多用户.多任务.支持多线程和多CPU的操作系统.它能运行主要的UNI ...
- 科普Spark,Spark是什么,如何使用Spark
科普Spark,Spark是什么,如何使用Spark 1.Spark基于什么算法的分布式计算(很简单) 2.Spark与MapReduce不同在什么地方 3.Spark为什么比Hadoop灵活 4.S ...
- idea 破解代码
下面是idea的破解方法,手动执行对应的main方法即可.亲测Idea 14 完美破解~~废话少说,上代码... package com.jd.serializable; import java.ma ...
- 安装scikit-image问题
参考地址: Image Processing Using Python https://code.tutsplus.com/tutorials/image-processing-using-pytho ...
- Monkey Test 命令使用
1. 命令使用 Monkey是一个命令列工具 ,可以运行在仿真器里或实际设备中.它向系统发送伪随机的使用者事件流,实现对正在开发的应用程序进行压力测试.Monkey包括许多选项,它们大致分为四大类: ...
- 浪潮openStack云
- Spring高级话题
Spring Aware 在实际项目中,你不可避免的要用到spring容器本身的功能资源,这时你的bean要意识到spring容器的存在,才能调用spring提供的资源.spring aware本来就 ...
- zookeeper的概念和基础
1.1ZooKeeper的使命 当开发人员使用ZooKeeper进行开发时,开发人员设计的那些应⽤往往可以看成成组连接到ZooKeeper服务器端的客户端,它们通过ZooKeeper的客户端API连接 ...
- HALCON初步:算子参数部分三个冒号的意义
HALCON中存在两类基本变量:图像变量(iconic data)和控制变量(control data),其中图像变量包括image, region和XLD contours,控制变量包括intege ...
- 在线浏览office 文件
http://blog.csdn.net/binyao02123202/article/details/20051683 [Asp.net]常见word,excel,ppt,pdf在线预览方案,有图有 ...