Java使用内存的程序检测
2018-01-19 12:52
316 查看
用top检查java程序时可以看到以下的参数
这些参数都是什么意思,该怎么理解呢?
网上查的资料说:
virt 7070m
你的java程序能访问的内存空间地址, 包括代码,数据,共享库,交换页等等, 这是一个虚拟映射, 并不是所有地址都有相应的物理内存对应, 所以可以是大于物理内存的.
res 2.5g
这个可能和你的java启动参数有关, 如 -Xmx2500m或比这个还大, 是程序占用的非交换的驻留内存.
shr 10m
占用内存的可共享部分,可能与其他进行共用.
%mem 4.0
占用内存的百分比
推测 2.5g/4%=62.5~你的机器有64G的物理内存
如果有这样一段代码
会占用多少内存呢?
我们看一下JDK6的源码
可以这样理解内存使用
真正消耗内存的是 new Object[initialCapacity], 大约是initialCapacity*4个字节, 算下来也不多.
list.add(“abcd”)增加了一个string对象加对象内部字符和属性(长度等)占用的内存.
可以用下面的小程序完成对内存使用的检验
代码里的Thread.sleep的作用是为了占用内存时间长一下,这样可以用终端指令进行监控
上面的程序执行后输出的结果为
上面(2)-(1) 4608352-608336= 4000016
对应的是ArrayList对象占16字节, elementData数组每个占4字节,共1Mx4=4M内存.
放入字符串后, 85200512-4608352=80592160, 大概我的每个测试字符串占用了80字节,实际字符平均20个, 每个字符占用的也是4个字节.
—–实践出真知—–
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 246 root 20 0 7070m 2.5g 10m S 0.4 4.0 58:42.39 java
这些参数都是什么意思,该怎么理解呢?
网上查的资料说:
virt 7070m
你的java程序能访问的内存空间地址, 包括代码,数据,共享库,交换页等等, 这是一个虚拟映射, 并不是所有地址都有相应的物理内存对应, 所以可以是大于物理内存的.
res 2.5g
这个可能和你的java启动参数有关, 如 -Xmx2500m或比这个还大, 是程序占用的非交换的驻留内存.
shr 10m
占用内存的可共享部分,可能与其他进行共用.
%mem 4.0
占用内存的百分比
推测 2.5g/4%=62.5~你的机器有64G的物理内存
如果有这样一段代码
List list = new ArrayList<String>(1000); list.add("abcd");
会占用多少内存呢?
我们看一下JDK6的源码
127 public ArrayList(int initialCapacity) { 128 super(); //调用AbstractList的默认构造函数,里面什么也没有做 129 if (initialCapacity < 0) 130 throw new IllegalArgumentException("Illegal Capacity: "+ 131 initialCapacity); 132 this.elementData = new Object[initialCapacity]; //创建一个数组对象 133 }
可以这样理解内存使用
new ArrayList<String>(1000);仅仅是分配并初始化了一个ArrayList对象. 并初始化的内部的数组对象
真正消耗内存的是 new Object[initialCapacity], 大约是initialCapacity*4个字节, 算下来也不多.
list.add(“abcd”)增加了一个string对象加对象内部字符和属性(长度等)占用的内存.
可以用下面的小程序完成对内存使用的检验
import java.util.*; public class test{ public static void print(){ long total = Runtime.getRuntime().totalMemory(); long used = Runtime.getRuntime().totalMemory() - Runtime.getRuntime().freeMemory(); System.out.println("total="+total+" used="+used); } public static void main(String[] args)throws Exception { print(); //(1) List<String> list = new ArrayList<>(1000000); print(); //(2) Thread.sleep(1000); int i=0; while(i++<1000000){ list.add(i+"test1234567890"); } print();//(3) Thread.sleep(10000); } }
代码里的Thread.sleep的作用是为了占用内存时间长一下,这样可以用终端指令进行监控
top -p `pgrep java`
上面的程序执行后输出的结果为
total=55574528 used=608336 (1) total=55574528 used=4608352 (2) total=204472320 used=85200512 (3)
上面(2)-(1) 4608352-608336= 4000016
对应的是ArrayList对象占16字节, elementData数组每个占4字节,共1Mx4=4M内存.
放入字符串后, 85200512-4608352=80592160, 大概我的每个测试字符串占用了80字节,实际字符平均20个, 每个字符占用的也是4个字节.
—–实践出真知—–
相关文章推荐
- 使用instrument检测ios程序内存问题
- valgrind 使用 (linux程序内存检测)
- 用MAT分析JAVA程序运行时的内存使用情况
- Java程序内存分析:使用mat工具分析内存占用
- 检测Python程序执行效率及内存和CPU使用的7种方法
- Java 程序查看JVM内存使用
- 使用instrument检测ios程序内存问题
- 使用Visual Leak Detect or 检测c/ c++ 程序内存泄漏
- 如何使用JVisualVM远程监控和优化Tomcat和Java程序的内存和CPU
- 检测Python程序执行效率及内存和CPU使用的7种方法
- Java程序内存分析:使用mat工具分析内存占用
- 检测Windows程序中的内存使用错误
- Java程序内存分析:使用mat工具分析内存占用
- Java程序内存分析:使用mat工具分析内存占用
- Java程序内存分析:使用mat工具分析内存占用
- 使用jmap和MAT观察Java程序内存数据
- JAVA内存泄露检测工具如何使用
- 使用valgrind检测Android native程序的内存
- 如何配置来增加eclipse下运行java程序的jvm使用内存
- 使用instrument检测ios程序内存问题