对象在内存中的存储机制

来源:互联网 发布:舞蹈 知乎 编辑:程序博客网 时间:2024/06/14 06:52

数据类型和对象在内存中的处理方法是有差别的。拿数组举例

 

 

数组建立时候会在内存中分别存放到两个地方

数组的元素会被放在堆(heap)中,数组引用变量存储在栈(stack)中.

下面的程序输出可以说明这个问题,数组变量只是引用地址.

现在我明白2000年写代码的时候把HashTable放到数组中,为什么改变的时候不是我想的样子了.

下面的代码非常简单,但是我把他变成面试题,真正写对的人数少的让人惊讶(面试大约50人左右只有2个人答对了).

  

run-main:
3:4
----------a---------
3
4
5
----------b---------
0
0
0
0
-------------------
----------a---------
3
4
5
----------b---------
3
4
5
-------------------
----------a---------
3
99
5
----------b---------
3
99
5
成功生成(总时间:4 秒)