Runtime类中的freeMemory,totalMemory,maxMemory等几个方法

简介:

最近在网上看到一些人讨论到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 运行,看看结果如何,有助于理解上面的阐述。

    1. public class Untitled1 { 
    2. public Untitled1() {} 
    3. public static void main(String[] args) { 
    4. System.out.println(Runtime.getRuntime().freeMemory()); 
    5. System.out.println(Runtime.getRuntime().totalMemory()); 
    6. System.out.println(Runtime.getRuntime().maxMemory()); 
    7. long t = System.currentTimeMillis(); 
    8. try 
    9. Thread.sleep(30000); 
    10. catch (Exception ee) { 
    11. ee.printStackTrace(); 
    12. String[]?aaa?=?new?String[2000000]; 
    13. System.out.println(Runtime.getRuntime().freeMemory()); 
    14. System.out.println(Runtime.getRuntime().totalMemory()); 
    15. System.out.println(Runtime.getRuntime().maxMemory()); 
    16. try{
    17. Thread.sleep(30000);
    18. }catch (Exception ee){
    19. ee.printStackTrace();
    20. }
    21. for(int i=0;i<2000000;i++){
    22. aaa[i]=new?String("aaa");
    23. }
    24. System.out.println(Runtime.getRuntime().freeMemory());
    25. System.out.println(Runtime.getRuntime().totalMemory());
    26. System.out.println(Runtime.getRuntime().maxMemory());
    27. try{
    28. Thread.sleep(30000);
    29. }catch(Exception?ee){
    30. ee.printStackTrace();
    31. }
    32. }
    33. }

本文转自农夫山泉别墅博客园博客,原文链接:http://www.cnblogs.com/yaowen/p/6347776.html,如需转载请自行联系原作者
相关文章
|
3月前
|
Java 编译器
【一步一步了解Java系列】:子类继承以及代码块的初始化
【一步一步了解Java系列】:子类继承以及代码块的初始化
145 3
|
3月前
|
Java
java构造方法时对象初始化,实例化,参数赋值
java构造方法时对象初始化,实例化,参数赋值
93 1
|
3月前
|
Java
java中父类方法return this.对象还是变量,子类去调用this.这个方法的问题
本文探讨了在Java中,当父类的方法返回`this`对象或变量时,子类调用该方法的行为,以及`this`关键字在不同类中调用方法时的指向问题。
21 0
java中父类方法return this.对象还是变量,子类去调用this.这个方法的问题
|
7月前
|
安全 NoSQL Java
探索Java Optional类:构造器、成员变量与方法
探索Java Optional类:构造器、成员变量与方法
|
8月前
|
存储 Java
Java的接口、类、属性、方法的修饰符使用总结
Java的接口、类、属性、方法的修饰符使用总结
420 0
|
Java
Java 反射之调用运行时类中指定的属性
Java 反射之调用运行时类中指定的属性
54 0
|
Java
Java类实例化时执行顺序
Java类实例化时执行顺序
115 0
|
Java
使用lombok的@Builder的注解:Error:java: 无法将类中的构造器应用到给定类型
使用lombok的@Builder的注解:Error:java: 无法将类中的构造器应用到给定类型
1216 0
使用lombok的@Builder的注解:Error:java: 无法将类中的构造器应用到给定类型
|
设计模式 Java 开发者
Runtime 类|学习笔记
快速学习 Runtime 类
133 0
Runtime 类|学习笔记
|
Java C# C++
Java 静态方法和实例化方法的区别
Java 静态方法和实例化方法的区别
137 0

热门文章

最新文章