zoukankan      html  css  js  c++  java
  • 谈谈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()可 能会有些大。

    自己写了个例子,对着测试 结果应该会有更深刻的了解:

    [java] view plaincopy
     
    1. package com.trs.tb.encrypt;  
    2.   
    3. public class TestMemory {  
    4.     public static void main(String[] args) {  
    5.         System.out.println("free:" + Runtime.getRuntime().freeMemory() / 1024  
    6.                 / 1024);  
    7.         System.out.println("total:" + Runtime.getRuntime().totalMemory() / 1024  
    8.                 / 1024);  
    9.         System.out.println("max:" + Runtime.getRuntime().maxMemory() / 1024  
    10.                 / 1024);  
    11.         System.out.println("=============");  
    12.         long t = System.currentTimeMillis();  
    13.         try {  
    14.             Thread.sleep(3000);  
    15.         } catch (Exception ee) {  
    16.             ee.printStackTrace();  
    17.         }  
    18.         String[] aaa = new String[2000000];  
    19.         System.out.println(Runtime.getRuntime().freeMemory() / 1024 / 1024);  
    20.         System.out.println(Runtime.getRuntime().totalMemory() / 1024 / 1024);  
    21.         System.out.println(Runtime.getRuntime().maxMemory() / 1024 / 1024);  
    22.         System.out.println("=============");  
    23.         try {  
    24.             Thread.sleep(3000);  
    25.         } catch (Exception ee) {  
    26.             ee.printStackTrace();  
    27.         }  
    28.         for (int i = 0; i < 2000000; i++) {  
    29.             aaa[i] = new String("aaa");  
    30.         }  
    31.         System.out.println(Runtime.getRuntime().freeMemory() / 1024 / 1024);  
    32.         System.out.println(Runtime.getRuntime().totalMemory() / 1024 / 1024);  
    33.         System.out.println(Runtime.getRuntime().maxMemory() / 1024 / 1024);  
    34.         System.out.println("=============");  
    35.         try {  
    36.             Thread.sleep(30000);  
    37.         } catch (Exception ee) {  
    38.             ee.printStackTrace();  
    39.         }  
    40.     }  
    41. }  


    执行时间

    free:4
    total:4
    max:63
    =============
    4
    12
    63
    =============
    9
    63
    63
    =============

  • 相关阅读:
    深入理解iOS开发中的锁
    整理:iOS开发算法资料
    (二)ELK Filebeat简介
    (一)ELK 部署
    zabbix + grafana 展示
    (二)LVS介绍
    (一)集群介绍
    zabbix 监控 ESXI
    zabbix proxy 安装
    zabbix fping 监控网络质量
  • 原文地址:https://www.cnblogs.com/hushaojun/p/4944619.html
Copyright © 2011-2022 走看看