如果从浅层次,从易于理解的层次来讲,Java中内存可以划分为四块:
A-栈内存区(stacksegment):可以保存对象的名称(保存,访问堆内存的地址),引用类型变量所占用的两块内存区之一,比如Point point = new Point() ; 那么这个Point对象的引用“point”就会存与栈内存中,它没有实际的Point的实例化对象,可以理解为它只包含一个物理地址,这个物理地址指向的就是存在于堆内存中的,那个new出来Point的实例化对象,这个实例化对象才具有一系列Point对象应该具有的属性,比如X、Y横纵坐标等事先定义好的属性。
B-堆内存(heapsegment):保存每个对象的具体属性,或者说,保存所有new出来的东西。所占用Java内存最大,因为要实现内存的动态分配,当其中一个属性,或者说一小块内存不再使用时,Java著名的垃圾回收机制就会将其回收……
C-全局数据区(datasegment):保存static类型的属性以及String引用类型变量。关于String类型变量的储存这里有一个值得注意的地方:如果我们String s1 = new String (“Hello”);String s2 = new String (“Hello”);System.out.println(s1 == s2);输出结果是什么呢?是true!
我们知道“==”在这里比较的是是两个引用是否指向同一个对象,或者说两个引用的物理地址(这里说哈希码应该更恰当些)是否相同,那么为什么会输出true呢?他们难道不是两个不同的对象吗?原因是:datasegment有一个神奇的功能,一个引用(存在于Stack segment中),在datasegment中所指向的那块内存中的内容如果在datasegment中已经存在了的话,就不会再生成一块重复的内存了,而是让该引用指向那块原有的内存~
D-全局代码区(codesegment):保存所有方法的定义,所有的方法的完整的代码都在里边。