数组与其他种类的容器之间的区别主要有三方面:效率、类型和保存基本数据的能力。现在Java中的容器具有自动包装的功能,使得容器与数组看起来二者之间的区别更小了。在java中数组就是一个简单的线性序列,所以在访问数组的元素师非常的快速,然而这些所必须付出的代价就是数组对象的大小是固定的,而且在其生命周期内是不可以被改变的。
我们在前面提到了泛型,由于擦除会擦除掉运行时泛型的参数信息,然而数组必须要知道保存在其中的类型信息,所以数组与泛型并不能很好的结合,例如我们不能实例化具有参数化类型的数组:
public class Test<T> {
public static void main(String[] args) {
// Cannot create a generic array of Test<String>
Test<String>[] tests = new Test<String>[10];
}
}
当我我们可以Object类型的数组然后进行转型。
数组有一个重要的用途,就是我们可以创建测试数据用的数组,这里我们会使用到策略设计模式:
例如:
public class RandomGenerator<T> {
private static Random r = new Random(47);
public static class Boolean implements Generator<java.lang.Boolean>{
public java.lang.Boolean next(){
return r.nextBoolean();
}
}
public static class Integer implements Generator<java.lang.Integer>{
public java.lang.Integer next(){
return r.nextInt();
}
}
}
在java.util类库中存在一个Arrays类,具有一些用于数组的static方法,如:
equasl(),deepEquals();fill();sort();binarySearch();toString();hashcode()以及Arrays.asLis()。
其中binarySearch(),必须在排序后的数组中才可以使用。
数组比较的简单,我们在以后的编程中,尽量选择容器而不是数组,只是在非常注重性能是在考虑使用数组。