aidia64的runtime totalmemory memory是什么意思

红米手机 &
电视盒子 &
智能硬件 &
骨灰级手机控
扫码下载App一键签到 升级加速
硬件检测Ese Memory Total是红色,是什么意思?
扫一扫!手机看帖更爽
就是下面这样,问客服也不知道
扫描二维码,手机查看本帖
关了NFC就正常了。。。
京ICP证110507号 京ICP备号谈谈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*字节,这是java虚拟机默认情况下能 从操作系统那里挖到的最大的内存。如果添加了-Xmx参数,将以这个参数后面的值为准,例如java -cp ClassPath -Xmx512m ClassName,那么最大内存就是512*字节。totalMemory()这个方法返回的是java虚拟机现在已经从操作系统那里挖过来的内存大小,也就是java虚拟机这个进程当时所占用的所有 内存。如果在运行java的时候没有添加-Xms参数,那么,在java程序运行的过程的,内存总是慢慢的从操作系统那里挖的,基本上是用多少挖多少,直 挖到maxMemory()为止,所以totalMemory()是慢慢增大的。如果用了-Xms参数,程序在启动的时候就会无条件的从操作系统中挖- Xms后面定义的内存数,然后在这些内存用的差不多的时候,再去挖。freeMemory()是什么呢,刚才讲到如果在运行java的时候没有添加-Xms参数,那么,在java程序运行的过程的,内存总是慢慢的从操 作系统那里挖的,基本上是用多少挖多少,但是java虚拟机100%的情况下是会稍微多挖一点的,这些挖过来而又没有用上的内存,实际上就是 freeMemory(),所以freeMemory()的值一般情况下都是很小的,但是如果你在运行java程序的时候使用了-Xms,这个时候因为程 序在启动的时候就会无条件的从操作系统中挖-Xms后面定义的内存数,这个时候,挖过来的内存可能大部分没用上,所以这个时候freeMemory()可 能会有些大。
自己写了个例子,对着测试 结果应该会有更深刻的了解:
package&com.trs.tb.&&
public&class&TestMemory&{&&
&&&&public&static&void&main(String[]&args)&{&&
&&&&&&&&System.out.println("free:"&+&Runtime.getRuntime().freeMemory()&/&1024&&
&&&&&&&&&&&&&&&&/&1024);&&
&&&&&&&&System.out.println("total:"&+&Runtime.getRuntime().totalMemory()&/&1024&&
&&&&&&&&&&&&&&&&/&1024);&&
&&&&&&&&System.out.println("max:"&+&Runtime.getRuntime().maxMemory()&/&1024&&
&&&&&&&&&&&&&&&&/&1024);&&
&&&&&&&&System.out.println("=============");&&
&&&&&&&&long&t&=&System.currentTimeMillis();&&
&&&&&&&&try&{&&
&&&&&&&&&&&&Thread.sleep(3000);&&
&&&&&&&&}&catch&(Exception&ee)&{&&
&&&&&&&&&&&&ee.printStackTrace();&&
&&&&&&&&}&&
&&&&&&&&String[]&aaa&=&new&String[2000000];&&
&&&&&&&&System.out.println(Runtime.getRuntime().freeMemory()&/&1024&/&1024);&&
&&&&&&&&System.out.println(Runtime.getRuntime().totalMemory()&/&1024&/&1024);&&
&&&&&&&&System.out.println(Runtime.getRuntime().maxMemory()&/&1024&/&1024);&&
&&&&&&&&System.out.println("=============");&&
&&&&&&&&try&{&&
&&&&&&&&&&&&Thread.sleep(3000);&&
&&&&&&&&}&catch&(Exception&ee)&{&&
&&&&&&&&&&&&ee.printStackTrace();&&
&&&&&&&&}&&
&&&&&&&&for&(int&i&=&0;&i&&&2000000;&i++)&{&&
&&&&&&&&&&&&aaa[i]&=&new&String("aaa");&&
&&&&&&&&}&&
&&&&&&&&System.out.println(Runtime.getRuntime().freeMemory()&/&1024&/&1024);&&
&&&&&&&&System.out.println(Runtime.getRuntime().totalMemory()&/&1024&/&1024);&&
&&&&&&&&System.out.println(Runtime.getRuntime().maxMemory()&/&1024&/&1024);&&
&&&&&&&&System.out.println("=============");&&
&&&&&&&&try&{&&
&&&&&&&&&&&&Thread.sleep(30000);&&
&&&&&&&&}&catch&(Exception&ee)&{&&
&&&&&&&&&&&&ee.printStackTrace();&&
&&&&&&&&}&&
执行时间:
free:4total:4max:63=============41263=============96363=============
随笔 - 621谈谈Runtime类中的freeMemory,totalMemory,maxMemory等几个方法 - 7sunet - ITeye博客
最近在网上看到一些人讨论到java.lang.Runtime类中的freeMemory(),totalMemory(),maxMemory ()这几个方法的一些问题,很多人感到很疑惑,为什么,在java程序刚刚启动起来的时候freeMemory()这个方法返回的只有一两兆字节,而随着 java程序往前运行,创建了不少的对象,freeMemory()这个方法的返回有时候不但没有减少,反而会增加。这些人对freeMemory()这 个方法的意义应该有一些误解,他们认为这个方法返回的是操作系统的剩余可用内存,其实根本就不是这样的。这三个方法反映的都是java这个进程的内存情 况,跟操作系统的内存根本没有关系。下面结合totalMemory(),maxMemory()一起来解释。
maxMemory()这个方法返回的是java虚拟机(这个进程)能构从操作系统那里挖到的最大的内存,以字节为单位,如果在运行java程序的时 候,没有添加-Xmx参数,那么就是64兆,也就是说maxMemory()返回的大约是64*字节,这是java虚拟机默认情况下能 从操作系统那里挖到的最大的内存。如果添加了-Xmx参数,将以这个参数后面的值为准,例如java -cp ClassPath -Xmx512m ClassName,那么最大内存就是512*字节。
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();
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());
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());
Thread.sleep(30000);
} catch (Exception ee) {
ee.printStackTrace();
转自: /archives/133
浏览 13485
yzjiang8888
浏览: 28239 次
来自: 北京
最近准备弄个网站,需要这样技术处理
hxpterry 写道目前的web项目都倾向于用轻量级的技术方 ...
这种情况服务器迁移,域名换了之类的事情发生时候,数据库里面需要 ...
目前的web项目都倾向于用轻量级的技术方案,一来组件结构简单明 ...

我要回帖

更多关于 totalmemory 的文章

 

随机推荐