JVM有多种实现,例如Oracle的JVM,HP的JVM和IBM的JVM等,而在本文中研究学习的则是使用最广泛的Oracle的HotSpot JVM
JDK是java开发的必备工具箱,JDK其中有一部分是JRE,JRE是JAVA运行环境,JVM则是JRE最核心的部分
JVM由4大部分组成:ClassLoader,Runtime Data Area,Execution Engine,Native Interface
Runtime Data Area 则是存放数据的, 分为五部分:Stack,Heap,Method Area,PC Register,Native Method Stack。几乎所有的关于java内存方面的问题 , 都是集中在这块。
Java把内存分成两种,一种叫做栈(Stack)内存,一种叫做堆(Heap)内存.
在函数中定义的一些基本类型的变量和对象的引用变量都在函数的栈内存中分配.当在一段代码块定义一个变量时,Java就在栈中为这个变量分配内存空间,当超过变量的作用域后,Java会自动释放掉为该变量所分配的内存空间,该内存空间可以立即被另作他用.
堆内存用来存放由new创建的对象和数组。 在堆中分配的内存,由Java虚拟机的自动垃圾回收器来管理。在堆中产生了一个数组或对象后,还可以在栈中定义一个特殊的变量,让栈中这个变量的取值等于数组或对象在堆内存中的首地址,栈中的这个变量就成了数组或对象的引用变量。引用变量就相当于是为数组或对象起的一个名称,以后就可以在程序中使用栈中的引用变量来访问堆中的数组或对象
http://www.cnblogs.com/angeldevil/p/3801189.html
http://www.open-open.com/lib/view/open1437834571349.html
http://www.cnblogs.com/sunada2005/p/3577799.html
http://www.cnblogs.com/whgw/archive/2011/09/29/2194997.html
Java内存泄露原因详解
http://blog.csdn.net/seelye/article/details/8269705
JVM调优总结
http://blog.sina.com.cn/s/blog_3f12afd00100zpvf.html
http://www.blogjava.net/cpegtop/articles/377081.html