首页 > 其他 > 详细

ArrayList增、删、改方法实现

时间:2017-04-04 22:52:26      阅读:135      评论:0      收藏:0      [点我收藏+]

技术分享

         技术分享

  1 //ArrayList增、删、查代码具体实现
  2 
  3 package com.coding.basic;
  4 
  5 import java.util.Arrays;
  6 
  7 public class MyArrayList implements List {
  8 
  9     private static final int DEFAULT_CAPACITY = 10;
 10     private int size = 0;
 11 
 12     Object[] elementData;
 13 
 14     // 默认数组容量是10
 15     public MyArrayList() {
 16         this(DEFAULT_CAPACITY);
 17     }
 18 
 19     // 传入数组容量
 20     public MyArrayList(int capacity) {
 21 
 22         if (capacity < 0) {
 23 
 24             throw new IllegalArgumentException("Illegal Capacity: " + capacity);
 25         }
 26         if (capacity >= 0) {
 27             elementData = new Object[capacity];
 28             size = elementData.length;
 29         }
 30     }
 31 
 32     // 保证数组容量
 33     private void ensurecapacity(int mincapacity) {
 34 
 35         int oldcapacity = elementData.length;
 36         if (mincapacity > oldcapacity) {
 37             Object olddata[] = elementData;
 38             // 1.5倍括容是最好的倍數
 39             int newcapacity = oldcapacity * 3 / 2;
 40 
 41             if (mincapacity > newcapacity) {
 42                 newcapacity = mincapacity;
 43             }
 44             elementData = Arrays.copyOf(elementData, newcapacity);
 45         }
 46 
 47     }
 48 
 49     // 在尾部添加元素
 50     public void add(Object o) {
 51         ensurecapacity(size + 1);
 52         elementData[size++] = o;
 53 
 54     }
 55 
 56     // 在任意位置添加元素
 57     public void add(int index, Object o) {
 58         RangeCheck(index);
 59         ensurecapacity(size + 1);
 60         for (int x = size - 1; x > index; x--) {
 61             elementData[x + 1] = elementData[x];
 62 
 63         }
 64         elementData[index + 1] = o;
 65     }
 66 
 67     // 获取任意位置上的元素
 68     public Object get(int index) {
 69         RangeCheck(index);
 70 
 71         return elementData[index];
 72 
 73     }
 74 
 75     // 检查索引值范围
 76     private void RangeCheck(int index) {
 77         if (index < 0 || index >= size) {
 78             throw new IndexOutOfBoundsException("Index: " + index + ", Size: " + size);
 79         }
 80 
 81     }
 82 
 83     // 删除任意位置元素并返回该元素
 84     public Object remove(int index) {
 85         return remove(index, elementData);
 86     }
 87 
 88     // 删除任意位置元素并返回该元素
 89     public Object remove(int index, Object[] elementData) {
 90         RangeCheck(index);
 91         if (index >= 0 && index < size - 1) {
 92             for (int i = index; i < size - 1; i++) {
 93                 elementData[i] = elementData[i + 1];
 94 
 95             }
 96 
 97         }
 98         if (index == size - 1) {
 99             elementData[index] = elementData[size - 1];
100         }
101 
102         size--;
103         return elementData[index];
104     }
105 
106     // 获取数组长度
107     public int size() {
108         return size;
109     }
110 
111 }

 

ArrayList增、删、改方法实现

原文:http://www.cnblogs.com/lond/p/6666759.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!