目录
一、什么是动态数组
二、动态数组的实现
一、什么是动态数组
Java中提供的数组都是静态数组,即在一个数组定义时确定长度后,使用过程中无法修改此长度。
动态数组就是在普通数组上,增加了一个可以根据元素的个数动态调整数组大小的功能。
二、动态数组的实现
1.创建一个Object类型的value数组,设置数组长度为length,数组元素数为size,并且初始化构造方法
public class MyList {
Object[] values;// 什么数据都可以存
int length;//数组长度
int size;//数组元素数量
//初始化构造方法
public MyList(int initLength){
if(initLength<=0){
System.err.println ("initLength 小于或者等于 0 不合法!! ");
// 默认初始 长度设定为10
length = 10;
values = new Object[length];
size=0;
}else{
length = initLength;
values = new Object[length];
size=0;
}
}
2.通过实现添加数组元素、获取数组元素、移除数组元素、代替数组元素的功能来实现动态数组
(1)添加数组元素
- 创建一个新数组,长度比原来的数组大
- 遍历原数组元素,将原数组中的元素存入新数组中,替换引用
public void add(Object e){
// 检测 数组的空间是否足够
if(size>=length){
// 扩容 : 创建一个新数组,长度比原来数组大,将原数组中的数据存入新数组中,替换引用
int oldlength = length;
int newlength = oldlength+(oldlength>>1);// 1.5倍扩容
// 新建数组
length = newlength;
Object[] newArr = new Object[length];
for(int i = 0; i < oldlength; i++){
newArr[i]=values[i];
}
// 迭代替换
values=newArr;
System.out.println ("扩容完成,新的长度为:"+length);
}
values[size]=e;
size++;
}
(2)获取数组元素
- 判断要获取的数组下标是否越界,若越界,报错
- 判断之后,直接返回要获取的数组元素
public Object get(int index) {
if (index < 0 || index >= size) {
System.err.println("下标越界!!!");
return null;
}
return values[index];
}
(3)移除数组元素
- 判断要获取的数组下标是否越界,若越界,报错
- 后置数据前移
public void remove(int index){
if(index<0 || index>=size){
System.err.println ("下标越界!!!");
return;
}
values[index]=null;
// 后置数据前移
for(int i=index;i<size-1;i++){
values[i] = values[i + 1];
}
values[size-1] = null;
// 更新size
size--;
System.out.println("新的数组为"+values);
}
(4)替换数组元素
- 判断要获取的数组下标是否越界,若越界,报错
- 替换新的数组元素
public Object replace(int index,Object value){
if(index<0 || index>=size){
System.err.println ("下标越界!!!");
return null;
}
//替换新的数组元素
Object oldvalue = values[index];
values[index] = value;
return oldvalue;
}