java --Runtime.getRuntime()内存查看

摘自: http://7sunet.iteye.com/blog/285007

java.lang.Runtime类中的freeMemory(),totalMemory(),maxMemory ()这几个方法的一些问题,很多人感到很疑惑,为什么,在java程序刚刚启动起来的时候freeMemory()这个方法返回的只有一两兆字节,而随着 java程序往前运行,创建了不少的对象,freeMemory()这个方法的返回有时候不但没有减少,反而会增加。这些人对freeMemory()这 个方法的意义应该有一些误解,他们认为这个方法返回的是操作系统的剩余可用内存,其实根本就不是这样的。这三个方法反映的都是java这个进程的内存情 况,跟操作系统的内存根本没有关系。下面结合totalMemory(),maxMemory()一起来解释。
1.maxMemory()
这个方法返回的是java虚拟机(这个进程)能构从操作系统那里挖到的最大的内存,以字节为单位,如果在运行java程序的时 候,没有添加-Xmx参数,那么就是64兆,也就是说maxMemory()返回的大约是6410241024字节,这是java虚拟机默认情况下能 从操作系统那里挖到的最大的内存。如果添加了-Xmx参数,将以这个参数后面的值为准,例如java -cp ClassPath -Xmx512m ClassName,那么最大内存就是512 * 1024 *1024字节。
2.totalMemory()
这个方法返回的是java虚拟机现在已经从操作系统那里挖过来的内存大小,也就是java虚拟机这个进程当时所占用的所有 内存。如果在运行java的时候没有添加-Xms参数,那么,在java程序运行的过程的,内存总是慢慢的从操作系统那里挖的,基本上是用多少挖多少,直 挖到maxMemory()为止,所以totalMemory()是慢慢增大的。如果用了-Xms参数,程序在启动的时候就会无条件的从操作系统中挖- Xms后面定义的内存数,然后在这些内存用的差不多的时候,再去挖。
3.freeMemory()
是什么呢,刚才讲到如果在运行java的时候没有添加-Xms参数,那么,在java程序运行的过程的,内存总是慢慢的从操 作系统那里挖的,基本上是用多少挖多少,但是java虚拟机100%的情况下是会稍微多挖一点的,这些挖过来而又没有用上的内存,实际上就是 freeMemory(),所以freeMemory()的值一般情况下都是很小的,但是如果你在运行java程序的时候使用了-Xms,这个时候因为程 序在启动的时候就会无条件的从操作系统中挖-Xms后面定义的内存数,这个时候,挖过来的内存可能大部分没用上,所以这个时候freeMemory()可 能会有些大 。

下面举例说明下:

public class Test {

    public static void main(String[] args) {
        try {
            StringBuilder sb = new StringBuilder("abc123456");
            System.out.println("init-total:"+Runtime.getRuntime().totalMemory()/1024/1024);
            System.out.println("init-max:"+Runtime.getRuntime().maxMemory()/1024/1024);
            System.out.println("init-free:"+Runtime.getRuntime().freeMemory()/1024/1024);
            for(int i=0;i<100000000;i++){
                sb.append(new Random().nextInt(88888888) + new Random().nextInt(99999999));
                if(i%1000000==0){
                    System.out.println("total:"+Runtime.getRuntime().totalMemory()/1024/1024);
                    System.out.println("max:"+Runtime.getRuntime().maxMemory()/1024/1024);
                    System.out.println("free:"+Runtime.getRuntime().freeMemory()/1024/1024);
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

java --Runtime.getRuntime()内存查看_第1张图片
java初始化内存300M,最大为1000M,执行后发现init-max和init-total和设置类似
java --Runtime.getRuntime()内存查看_第2张图片
最终报内存溢出,从最后内存占用情况进程最大是889M,已经分配879M,相当于把最大内存全部玩过来,可用free内存只剩173M。由于测试是循环100000才打印一次,最后173M在这过程中不足以够用,导致报错.

你可能感兴趣的:(Java,java内存,totalMemory(),maxMemory(),freeMemory())