堆与栈的解析-以数组为例,解析数组在内存中的分布(JAVA基础-课堂笔记)

 

 

-、数组在内存中的分布解析

int[] x=new int[3];
任何程序在内存中运行,内存都要给它分配空间,JAVA在内存中分布的两个内存空间为:栈与堆。
栈:是用来存放局部定义的内容(变量),且栈内存中的内容只要不被使用,就会立即释放(最明显的就是for循环)
堆:是用来存放实体(数组和对象都在堆内存当中)。


任何一个实体在堆内存中产生,都会有一个首先的头地址x[0](内存释放的时候也从头地址值开始),也就是内存分配空间的起始位(我们可以形象的把它看作是一个房间的门牌号),头地址值在内存中以16进制的形式存在。
以上面的数组声明为例:右边的new int[3]存放在堆内存中,且分配三个内存空间(x[0]、x[1]、x[2]);左边的x存放在栈内存中。x[0]就是int[3]的头地址值,假设以16进制的形式表示为"0x0001",赋值号"="将右边的值赋给左边,其实就是把堆内存中的地址值(例如"0x0001")赋给了栈内存中的x,x通过这个地址值就指向了堆内存中的实体(我们也可以形象的做个类似:就像你把你家的门牌号告诉我,我就能找到你家一样)。这就叫做x引用堆内存中的数组实体(引用数据类型)。
堆内存的特点:1、内存中的实体都有内存地址值2、堆内存中的变量都有默认初始化值3、垃圾回收机制。

 

二、程序在内存中的分布及执行过程图

posted @ 2011-11-19 15:12  中国聚龙  阅读(630)  评论(0编辑  收藏  举报