java.lang.Runtime类
来源:互联网 发布:河南知春商贸有限公司 编辑:程序博客网 时间:2024/05/22 07:45
最近在网上看到一些人讨论到java.lang.Runtime类中的freeMemory(),totalMemory(),maxMemory()这几个方法的一些问题,很多人感到很疑惑,为什么,在java程序刚刚启动起来的时候freeMemory()这个方法返回的只有一两兆字节,而随着java程序往前运行,创建了不少的对象,freeMemory()这个方法的返回有时候不但没有减少,反而会增加。这些人对freeMemory()这个方法的意义应该有一些误解,他们认为这个方法返回的是操作系统的剩余可用内存,其实根本就不是这样的。这三个方法反映的都是java这个进程的内存情况,跟操作系统的内存根本没有关系。下面结合totalMemory(),maxMemory()一起来解释。
maxMemory()这个方法返回的是java虚拟机(这个进程)能构从操作系统那里挖到的最大的内存,以字节为单位,如果在运行java程序的时候,没有添加-Xmx参数,那么就是64兆,也就是说maxMemory()返回的大约是64*1024*1024字节,这是java虚拟机默认情况下能从操作系统那里挖到的最大的内存。如果添加了-Xmx参数,将以这个参数后面的值为准,例如java -cp ClassPath -Xmx512m ClassName,那么最大内存就是512*1024*0124字节。
totalMemory()这个方法返回的是java虚拟机现在已经从操作系统那里挖过来的内存大小,也就是java虚拟机这个进程当时所占用的所有内存。如果在运行java的时候没有添加-Xms参数,那么,在java程序运行的过程的,内存总是慢慢的从操作系统那里挖的,基本上是用多少挖多少,直挖到maxMemory()为止,所以totalMemory()是慢慢增大的。如果用了-Xms参数,程序在启动的时候就会无条件的从操作系统中挖-Xms后面定义的内存数,然后在这些内存用的差不多的时候,再去挖。
freeMemory()是什么呢,刚才讲到如果在运行java的时候没有添加-Xms参数,那么,在java程序运行的过程的,内存总是慢慢的从操作系统那里挖的,基本上是用多少挖多少,但是java虚拟机100%的情况下是会稍微多挖一点的,这些挖过来而又没有用上的内存,实际上就是freeMemory(),所以freeMemory()的值一般情况下都是很小的,但是如果你在运行java程序的时候使用了-Xms,这个时候因为程序在启动的时候就会无条件的从操作系统中挖-Xms后面定义的内存数,这个时候,挖过来的内存可能大部分没用上,所以这个时候freeMemory()可能会有些大。
把下面的源代码编译以后,在class文件所在的目录里面,分别用java -cp . Untitled1 和java -cp . -Xms80m -Xmx80m Untitled1 运行,看看结果如何,有助于理解上面的阐述。
public class Untitled1 { public Untitled1() { } public static void main(String[] args) { System.out.println(Runtime.getRuntime().freeMemory()); System.out.println(Runtime.getRuntime().totalMemory()); System.out.println(Runtime.getRuntime().maxMemory()); long t = System.currentTimeMillis(); try { Thread.sleep(30000); } catch (Exception ee) { ee.printStackTrace(); } String[] aaa = new String[2000000]; System.out.println(Runtime.getRuntime().freeMemory()); System.out.println(Runtime.getRuntime().totalMemory()); System.out.println(Runtime.getRuntime().maxMemory()); try { Thread.sleep(30000); } catch (Exception ee) { ee.printStackTrace(); } for (int i = 0; i < 2000000; i++) { aaa[i] = new String("aaa"); } System.out.println(Runtime.getRuntime().freeMemory()); System.out.println(Runtime.getRuntime().totalMemory()); System.out.println(Runtime.getRuntime().maxMemory()); try { Thread.sleep(30000); } catch (Exception ee) { ee.printStackTrace(); } } }
- java.lang.Runtime类
- java.lang.Runtime类
- java.lang.Runtime类
- 认识java.lang.Runtime类
- java.lang.Runtime类总结
- java.lang.Runtime类总结
- java--深入研究java.lang.Runtime类
- java.lang.System类与java.lang.Runtime类
- 深入研究java.lang.Runtime类
- 深入研究java.lang.Runtime类
- 深入研究java.lang.Runtime类
- 深入研究java.lang.Runtime类
- 深入研究java.lang.Runtime类
- 深入研究java.lang.Runtime类
- 深入研究java.lang.Runtime类
- 深入研究java.lang.Runtime类
- 深入研究java.lang.Runtime类
- java.lang.Runtime类知多少?
- ProgressDialog(五)——自定义ProgressDialog
- TCP/IP,Http,Socket,XMPP的区别
- vs2012编译QT
- JQuery+JSON+Struts2实现
- 好久没来了
- java.lang.Runtime类
- 关于 Xcode 中 NSAssert() 的用法 ,以及 assert() 与 NDEBUG
- char型注意的问题
- 逆向2048(win8)隐私策略
- Mongo连接池操纵MongoOptions
- QlikView Study Note
- 代码之路开启!干杯^_^
- C++Primer 第五版 3.类设计者的工具
- 关于controller的一些用法