数据类型和对象在内存中的处理方法是有差别的。拿数组举例
数组建立时候会在内存中分别存放到两个地方
数组的元素会被放在堆(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 秒)