Java实现自定义ArrayList类的示例代码
之前有接触过Collection中的ArrayList类,类中提供了多种可以操作的方法,但是为什么还需要自定义ArrayList类呢?主要是为了学习其中编写程序时的逻辑思维。,今天将简单的介绍ArrayList里面的add方法、size方法、isEmpty方法。
一、总体实现思路
在自定义ArrayList类时需要提前思考多个方面的内容
1、该ArrayList需要继承父接口List
2、需要重写父接口中的方法
3、需要用到的属性和方法:专门存放数据的数组elementData,由于不确定存放数据的数据类型所以这里将数组的数据类型定义为Object,需要一个成员变量count来记录数组里面元素的个数。
4、提供一个无参的构造方法以及有参的构造方法
5、根据需求修改方法里面的内容
二、add方法
该方法有两种,一种是形参只有一个的方法,另外一种是形参有两个的方法
形参只有一个的add方法
该方法起到添加的作用,将传进来的元素添加到已经定义好了的数组中
@Override
public boolean add(Object o) {
// 将传入的数据o放入数组中,该count是指代元素的个数
elementData[count] = o;
// 添加完成后需要将count加1
count++;
return true;
}
形参有两个的add方法
该方法第一个参数是需要插入的位置,第二个参数是需要插入的内容
@Override
public void add(int index, Object element) {
// todo 在指定位置插入元素
for (int i = count; i >index; i--) {
elementData[i]=elementData[i-1];
}
elementData[index]=element;
}

三、size方法
该方法返回集合的长度即数组的长度,跟开始定义的count有关
@Override
public int size() {
return count;
}
四、isEmpty方法
该方法只需要对count进行下判断,如果count为0则代表数组为空
@Override
public boolean isEmpty() {
return count==0;
}
五、构造方法
在构造方法中对数组进行初始化,定义数组的长度
public ArrayList(Object[] eleArr) {
this.elementData = eleArr;
}
public ArrayList() {
// todo 初始化数组的长度
elementData = new Object[10];
}
六、ArrayList整体代码
import java.util.Collection;
import java.util.Iterator;
import java.util.List;
import java.util.ListIterator;
public class ArrayList implements List {
/*
* 自定义实现ArrayList
* 1、要实现List接口
* 2、思考该类抽象出哪些属性-->数组用于保存元素的值elementData,数据类型为Object,用于计数的全局变量count
* 3、思考方法--一个全参的构造方法,一个不带参的构造方法
* 4、根据具体需求来实现具体的方法
* */
Object elementData[];
int count; // TODO 数组中的元素个数
@Override
public void add(int index, Object element) {
// todo 在指定位置插入元素
for (int i = count; i >index; i--) {
elementData[i]=elementData[i-1];
}
elementData[index]=element;
}
@Override
public boolean add(Object o) {
elementData[count] = o;
count++;
return true;
}
public ArrayList(Object[] eleArr) {
this.elementData = eleArr;
}
public ArrayList() {
// todo 初始化数组的长度
elementData = new Object[10];
}
@Override
public int size() {
return count;
}
@Override
public boolean isEmpty() {
return count==0;
}
@Override
public boolean contains(Object o) {
return false;
}
@Override
public Iterator iterator() {
return null;
}
@Override
public Object[] toArray() {
return new Object[0];
}
@Override
public boolean remove(Object o) {
return false;
}
@Override
public boolean addAll(Collection c) {
return false;
}
@Override
public boolean addAll(int index, Collection c) {
return false;
}
@Override
public void clear() {
}
@Override
public Object get(int index) {
return elementData[index];
}
@Override
public Object set(int index, Object element) {
return null;
}
@Override
public Object remove(int index) {
return null;
}
@Override
public int indexOf(Object o) {
return 0;
}
@Override
public int lastIndexOf(Object o) {
return 0;
}
@Override
public ListIterator listIterator() {
return null;
}
@Override
public ListIterator listIterator(int index) {
return null;
}
@Override
public List subList(int fromIndex, int toIndex) {
return null;
}
@Override
public boolean retainAll(Collection c) {
return false;
}
@Override
public boolean removeAll(Collection c) {
return false;
}
@Override
public boolean containsAll(Collection c) {
return false;
}
@Override
public Object[] toArray(Object[] a) {
return new Object[0];
}
}七、Test测试类
public class ArrayListTest {
public static void main(String[] args) {
ArrayList arrayList = new ArrayList();
arrayList.add("111");
arrayList.add("2222");
arrayList.add("3333");
System.out.println("集合中总共多少个元素:"+arrayList.size());
System.out.println("集合是否为空?"+arrayList.isEmpty());
System.out.println("集合第三个元素:"+arrayList.get(2));
arrayList.add(2,"新加的");
System.out.println("集合第三个元素:"+arrayList.get(2));
}
}到此这篇关于Java实现自定义ArrayList类的示例代码的文章就介绍到这了,更多相关Java自定义ArrayList类内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Java多线程编程之CountDownLatch同步工具使用实例
这篇文章主要介绍了Java多线程编程之CountDownLatch同步工具使用实例,需要的朋友可以参考下2015-05-05
SpringValidation数据校验之约束注解与分组校验方式
本文将深入探讨Spring Validation的核心功能,帮助开发者掌握约束注解的使用技巧和分组校验的高级应用,从而构建更加健壮和可维护的Java应用程序,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2025-04-04
深入了解Java中String、Char和Int之间的相互转换
这篇文章主要介绍了深入了解Java中String、Char和Int之间的相互转换,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,,需要的朋友可以参考下2019-06-06
POST方法给@RequestBody传参数失败的解决及原因分析
这篇文章主要介绍了POST方法给@RequestBody传参数失败的解决及原因分析,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-10-10
深入了解Maven Settings.xml文件的结构和功能
这篇文章主要为大家介绍了Maven Settings.xml文件基本结构和功能详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-11-11
volatile与happens-before的关系与内存一致性错误
本文讲了Java并发编程中volatile变量、happens-before与内存一致性错误,下面来和小编一起学习下如何解决2019-05-05


最新评论