首頁 > 軟體

Java實現自定義ArrayList類的範例程式碼

2022-08-12 22:00:58

之前有接觸過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類內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com