通过对List接口的实现类ArrayList的常见方法的应用

 

  

public class MyArrayList {

       private Object[] elementData;

       private int size;

  

       public int size() {

              return size;

       }

  

       public boolean isEmpty() {

              return size == 0;

       }

  

       public MyArrayList() {

              this(10);

       }

  

       public MyArrayList(int initialCapacity) {

              if (initialCapacity < 0) {

                     try {

                            throw new Exception();

                     } catch (Exception e) {

                            e.printStackTrace();

                     }

              }

              elementData = new Object[initialCapacity];

       }

  

       public void add(Object obj) {

  

              // 数组扩容

              if (size == elementData.length) {

                     Object[] newArray = new Object[size * 2 + 1];

                     System.arraycopy(elementData, 0, newArray, 0, elementData.length);

                     /*

                      * for (int i = 0; i < elementData.length; i++) {

                      * newArray[i]=elementData[i]; }

                      */

                     elementData = newArray;

              }

              elementData[size++] = obj;

              // size++;

       }

  

       public void add(int index, Object obj) {

              rangeCheck(index);

              ensureCapacity();//数组扩容

              

              System.arraycopy(elementData, index, elementData, index + 1, size - index);

              elementData[index] = obj;

              size++;

       }

  

       private void ensureCapacity() {

              // 数组扩容

              if (size == elementData.length) {

                     Object[] newArray = new Object[size * 2 + 1];

                     System.arraycopy(elementData, 0, newArray, 0, elementData.length);

                     /*

                      * for (int i = 0; i < elementData.length; i++) {

                      * newArray[i]=elementData[i]; }

                      */

                     elementData = newArray;

              }

  

       }

  

       public Object get(int index) {

              rangeCheck(index);

              return elementData[index];

       }

  

       public void remove(int index) {

              rangeCheck(index);

              // 删除指定位置的对象

              // a b c d e

              if (index < 0 || index >= size) {

                     try {

                            throw new Exception();

                     } catch (Exception e) {

                            e.printStackTrace();

                     }

                     int numMoved = size - index - 1;

                     if (numMoved > 0) {

                            System.arraycopy(elementData,

                     index + 1, elementData, index, numMoved);

                     }

                     elementData[--size] = null;

              }

       }

  

       public void remove(Object obj) {

              for (int i = 0; i < size; i++) {

                     if (get(i).equals(obj)) {// 注意:底层调用的equals方法,不是==;

                            remove(i);

                     }

              }

       }

  

       public Object set(int index, Object obj) {

              rangeCheck(index);

              Object oldValue = elementData[index];

              elementData[index] = obj;

              return oldValue;

       }

  

       private void rangeCheck(int index) {

              if (index < 0 || index >= size) {

                     try {

                            throw new Exception();

                     } catch (Exception e) {

                            e.printStackTrace();

                     }

              }

       }

  

       public static void main(String[] args) {

              MyArrayList slist = new MyArrayList(3);

              slist.add(132);

              slist.add("444");

              slist.add(5);

              slist.add("333");

              slist.add("333");

              slist.add("abc");

              slist.add("ccc");

              System.out.println(slist.size);

              System.out.println(slist.get(6));

       }

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

脸ル粉嘟嘟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值