今天一位校招的程序员在理解使用java.lang.Runtime类里的内存函数时,发生了一点小纠结,应用程序在LAXCUS大数据操作系统里运行时,发生了不必要的错误,经过检查排错,现在已经纠正。刚才查了一下JDK在线文档,解释也不甚清楚,所以在此记录下来,希望码友们也能正确理解和使用它们,不要再发生同类错误。

这三个函数是:
maxMemory();
totalMemory();
freeMemory();

三个函数返回参数都是长整型,以字节为单位。
maxMemory()表示从JVM能够从操作系统那里拿来的最大内存数。这个参数可以通过-Xmx在启动时设置。一旦运行,在整个运行过程中固定不变。如果用户没有设置,那么JVM默认是64M。
totalMemory()表示JVM现在从操作系统那里拿到的内存数。运行过程中,这个参数是随着程序申请内存量的增加,同步慢慢增加的。
JVM在给程序分配内存过程时,为避免频繁重复操作,并不是需要多少就分配多少,通常总是多分配一些。这多出来部分,就是freeMemory(),它属于totalMemory()中一段未使用内存。本次这位程序员的代码发生错误,就是在理解freeMemory()发生了歧义。

LAXCUS大数据操作系统在执行超载检查,判断内存使用量时,也都用到了这三个函数。你可以学习和得到全栈的大数据/云计算的系统架构知识,部署自己的大数据/云计算运行环境,开发自己的大数据/云计算/人工智能应用。LAXCUS大数据操作系统完整涵盖了open stack 、hadoop/spark、mysql、docker、ejb/corba的各项技术和功能,而又完全不同于它们!