数据类型和对象在内存中的处理方法是有差别的。拿数组举例
数组建立时候会在内存中分别存放到两个地方
数组的元素会被放在堆(heap)中,数组引用变量存储在栈(stack)中.
下面的程序输出可以说明这个问题,数组变量只是引用地址.
现在我明白2000年写代码的时候把HashTable放到数组中,为什么改变的时候不是我想的样子了.
下面的代码非常简单,但是我把他变成面试题,真正写对的人数少的让人惊讶(面试大约50人左右只有2个人答对了).
public class ArrayInRam { public static void main(String[] args) { int[] a = {3,4,5}; int[] b = new int[4]; System.out.println(a.length+":"+b.length); System.out.println("----------a---------"); for(int i:a){ System.out.println(i); } System.out.println("----------b---------"); for(int j:b){ System.out.println(j); } System.out.println("-------------------"); b=a; System.out.println("----------a---------"); for(int i:a){ System.out.println(i); } System.out.println("----------b---------"); for(int j:b){ System.out.println(j); } System.out.println("-------------------"); a[1]= 99; System.out.println("----------a---------"); for(int i:a){ System.out.println(i); } System.out.println("----------b---------"); for(int j:b){ System.out.println(j); } } }
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 秒)