-、数组在内存中的分布解析
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、垃圾回收机制。
二、程序在内存中的分布及执行过程图
======================================================
在最后,我邀请大家参加新浪APP,就是新浪免费送大家的一个空间,支持PHP+MySql,免费二级域名,免费域名绑定 这个是我邀请的地址,您通过这个链接注册即为我的好友,并获赠云豆500个,价值5元哦!短网址是http://t.cn/SXOiLh我创建的小站每天访客已经达到2000+了,每天挂广告赚50+元哦,呵呵,饭钱不愁了,\(^o^)/