数组:
在堆中连续开辟的一段空间,每个元素占有相同大小的空间。一经开辟,即固定大小,无法改变长短。
public void insetAtIndex(int index, int element) {
cheakRange(index); // 检查插入的是否超过数组开辟范围
cheakCapicity(); // 看是否需要扩容
for (int i = size; i > index; i--) {
elementDatas[i] = elementDatas[i - 1];
}
elementDatas[index] = element;
}
public int removeAtIndex(int index) {
// 检查删除的是否超过数组开辟范围
cheakRange(index);
int old = elementDatas[index];
for (int i = index + 1; i < size; i++) {
elementDatas[i - 1] = elementDatas[i];
}
//清空最后的空间
elementDatas[index] = null;
}
public int get(int index) {
// 判断查找的是否在范围内
cheakRange(index);
return elementDatas[i];
}
elementDatas[i] = element;
注意:在数组增删查改的时候,要判断是否在数组范围内操作。
在增加的时候,如果超过数组开辟空间范围,要对数组进行扩容:重新创建一个更大的数组,再将旧数组内容拷贝过去,再进行操作。