java实现动态数组
下面是关于Java实现动态数组的完整攻略:
什么是动态数组?
动态数组,简称为ArrayList,是在Java中使用较为广泛的数据结构之一。它是一种可变数组,可以根据需要自动扩展数组的大小。与传统的数组不同,动态数组的大小是可以根据需求动态增长或者缩小的。
Java中动态数组的实现
在Java中,动态数组的实现是通过内部维护一个Object数组来实现。当需要向动态数组中添加元素时,如果内部的Object数组已经满了,那么就需要重新创建一个更大的数组,并将原有数组中的元素复制到新数组中。具体实现可以参考以下示例代码:
public class ArrayList<E> {
private static final int DEFAULT_CAPACITY = 10;
private Object[] elements;
private int size;
public ArrayList() {
elements = new Object[DEFAULT_CAPACITY];
size = 0;
}
public ArrayList(int initialCapacity) {
elements = new Object[initialCapacity];
size = 0;
}
public void add(E e) {
if (size == elements.length) {
ensureCapacity(size + 1);
}
elements[size++] = e;
}
private void ensureCapacity(int minCapacity) {
if (minCapacity > elements.length) {
int newCapacity = elements.length * 2;
if (newCapacity < minCapacity) {
newCapacity = minCapacity;
}
elements = Arrays.copyOf(elements, newCapacity);
}
}
}
在上面的代码中,我们定义了一个ArrayList类,其中包含了两个构造函数,add()方法和ensureCapacity()方法。其中,add()方法用于向数组中增加元素,当数组已满时会自动扩容;而ensureCapacity()方法则是用来扩容的核心方法,它会根据当前要添加的元素个数来计算是否需要扩容,如果需要扩容则会按照一定的比例扩展数组的大小。
示例说明
下面我们通过两个示例来说明动态数组的使用。
示例一:添加元素
ArrayList<Integer> list = new ArrayList<>();
for (int i = 0; i < 20; i++) {
list.add(i);
}
System.out.println(list);
上述代码中,我们实例化了一个ArrayList对象,然后使用循环向其中添加了20个整数元素。由于ArrayList具有自动扩容的功能,因此不需要担心数组满了之后无法继续添加元素的问题。最后,我们将ArrayList对象打印出来,可以看到其中包含了20个元素。
示例二:删除元素
ArrayList<Integer> list = new ArrayList<>();
for (int i = 0; i < 20; i++) {
list.add(i);
}
list.remove(5);
System.out.println(list);
上述代码中,我们同样实例化了一个ArrayList对象,并使用循环向其中添加了20个整数元素。接着,我们调用了remove()方法,将第6个元素从ArrayList中删除。最后,我们将ArrayList对象打印出来,可以看到其中只包含了19个元素,因为第6个元素已经被删除了。
到此为止,Java中动态数组的完整攻略就讲解完了。当然,除了基本的添加和删除操作之外,ArrayList还支持许多其他的操作,例如获取元素、更新元素、查找元素等等。如果你对此感兴趣,可以继续深入了解。