package ArrayList;
/**
* <p>MyArrayList是个动态数组,初始容量为10的空列表</p>
* <p>在添加大量元素前,应用程序可以使用 ensureCapacity 操作来增加 ArrayList 实例的容量.这可
* 以减少递增式再分配的数量</p>
* @author baby69yy2000
*/
public class MyArrayList<T> {
private T[] listArr;
private int listSize;
/**
* 构造一个初始容量为10的空列表
*/
public MyArrayList() {
listArr = (T[]) new Object[10];
listSize = 0;
}
/**
* <p>方法ensureCapacity是MyArrayList类实现的一个重要操作, 它提供了允许ArrayList对象
* 进行动态增长的存储空间管理工具</p>
* <p>在MyArrayList对象的大小等于其容量时, 分配一个更大的数组, 并将已有值复制到新数组中</p>
* @param minCapacity 所需的最小容量
*/
public void ensureCapacity(int minCapacity) {
int currentCapacity = listArr.length;
if(minCapacity > currentCapacity) {
T[] oldlistArr = listArr;
listArr = (T[]) new Object[minCapacity];
for (int i = 0; i < listSize; i++) {
listArr[i] = oldlistArr[i];
}
oldlistArr = null;
}
}
/**
* 将此 MyArrayList 实例的容量调整为列表的当前大小
*/
public void trimToSize() {
int oldCapacity = listArr.length;
if(listSize < oldCapacity) {
T[] oldlistArr = listArr;
listArr = (T[]) new Object[listSize];
for (int i = 0; i < listSize; i++) {
listArr[i] = oldlistArr[i];
}
oldlistArr = null;
}
}
/**
* MyArrayList的连接
* 把listB放到listA的末尾
*/
public static <T> void joinList(MyArrayList<T> listA, MyArrayList<T> listB) {
int sizeA = listA.size(), sizeB = listB.size();
listA.ensureCapacity(sizeA + sizeB);
for(int i = 0; i < sizeB; i++)
listA.add(listB.get(i));
}
/**
* 求listArr的长度
* @return listArr长度
*/
public int listArrLength() {
return listArr.length;
}
/**
* 数组下标越界检查函数
*/
private void rangeCheck(int index, String s, int upperBound) {
if(index < 0 || index >= upperBound + 1) {
throw new IndexOutOfBoundsException("\n" + s + ": index" + index +
"out of bounds. Should be in the range 0 to " + upperBound);
}
}
/**
* 将指定的元素插入此列表中的指定位置.向右移动当前位于该位置的元素(如果有)以及所有后续元素
* (将其索引加 1)
* @param index 指定元素所插入位置的索引
* @param item 要插入的元素
* @throws IndexOutOfBoundsException
*/
public void add(int index, T item) {
rangeCheck(index, "MyArrayList add()", listSize);
if(listSize == listArr.length)
ensureCapacity(2*listArr.length);
for(int j = listSize - 1; j >= index; j--)
listArr[j + 1] = listArr[j];
listArr[index] = item;
listSize++;
}
/**
* 将指定的元素追加到此列表的尾部
* @param item 要追加到此列表中的元素
*/
public boolean add(T item) {
add(listSize, item);
return true;
}
/**
* 返回列表中首次出现指定元素的索引
* @param item 要搜索的元素
* @return 返回列表中手册出现指定元素的索引,如果列表不包含该元素,则返回 -1
*/
public int indexOf(T item) {
int i = 0;
int last = listSize - 1;
while(i <= last && listArr[i] != item) i++;
if(i > last) return -1;
else return i;
}
/**
* 移除此列表中指定位置上的元素. 向左移动所有后续元素(将其索引减 1)
* @param index 要移除的元素的索引
* @return 从列表中移除的元素
* @throws IndexOutOfBoundsException
*/
public T remove(int index) {
rangeCheck(index, "MyArrayList remove()", listSize - 1);
T returnElement = listArr[index];
for (int j = index; j < listSize - 1; j++)
listArr[j] = listArr[j + 1];
listArr[listSize - 1] = null;
listSize--;
return returnElement;
}
/**
* 移除列表中出现的首个指定元素
* @param item 要从此列表中移除的元素(如果存在)
* @return 如果此列表包含指定的元素,则返回 true
*/
public boolean remove(T item) {
int i = 0;
boolean returnValue = true;
if((i = indexOf(item)) != -1)
remove(i);
else
returnValue = false;
return returnValue;
}
/**
* 如果此列表中包含指定的元素,则返回 true
* @param item 要测试列表中是否存在的元素
* @return 如果列表包含指定的元素,则返回 true
*/
public boolean contains(T item) {
return indexOf(item) >=0;
}
/**
* 返回此列表中指定位置上的元素
* @param index 所返回元素的索引
* @return 此列表中指定位置上的元素
*/
public T get(int index) {
rangeCheck(index, "MyArrayList get()", listSize - 1);
return listArr[index];
}
/**
* 用指定的元素替代此列表中指定位置上的元素
* @param index 要替代的元素的索引
* @param item 指定的元素
* @return 以前位于该指定位置上的元素
*/
public T set(int index, T item) {
T oldValue = listArr[index];
listArr[index] = item;
return oldValue;
}
/**
* 返回一个按照正确的顺序包含此列表中所有元素的数组
* @return 一个按照正确的顺序包含此列表中所有元素的数组
*/
public Object[] toArray() {
Object[] result = new Object[listSize];
//System.arraycopy(listArr, 0, result, 0, listSize);
for (int i = 0; i < listSize; i++) {
result[i] = listArr[i];
}
return result;
}
/**
* 反转列表
*/
public void reverse() {
T temp;
int size = this.size();
for(int i = 0, j = listSize - 1, mid = size>>1; i < mid; i++, j--) {
temp = listArr[i];
listArr[i] = listArr[j];
listArr[j] = temp;
}
}
/**
* 返回此列表中的元素数
* @return 此列表中的元素数
*/
public int size() {
return listSize;
}
/**
* 测试此列表中是否有元素
* @return 如果此列表中没有元素,则返回 true;否则返回 false
*/
public boolean isEmpty() {
return listSize == 0;
}
/**
* 移除此列表中的所有元素
*/
public void clear() {
for (int i = 0; i < listSize; i++)
listArr[i] = null;
listSize = 0;
}
public static void main(String[] args) {
MyArrayList<String> listA = new MyArrayList<String>();
MyArrayList<String> listB = new MyArrayList<String>();
//mal.ensureCapacity(100);
listA.add("A");
listA.add("B");
listA.add("C");
listA.add("D");
listA.add("E");
listA.reverse();
//listB.add("F");
//listB.add("G");
//listA.joinList(listA, listB);
//listA.reverse();
for (int i = 0; i < listA.size(); i++) {
System.out.println(listA.get(i));
}
/*Object[] s = mal.toArray();
for (int i = 0; i < s.length; i++) {
System.out.println(s[i].toString());
}*/
//mal.trimToSize();
/*System.out.println(mal.listArrLength()); // 4
System.out.println(mal.size()); // 4
mal.clear();
System.out.println(mal.listArrLength()); // 4
System.out.println(mal.size());*/ // 0
/*mal.add(new Point(2, 3));
mal.add(new Point(8, 9));
Object[] objs = mal.toArray();
for (int i = 0; i < objs.length; i++) {
System.out.println(objs[i]);
}*/
/*System.out.println(mal.indexOf("C")); // 2
System.out.println(mal.indexOf("E")); // -1
System.out.println(mal.contains("A")); // true
System.out.println(mal.remove("B"));
mal.add(2, "BB");
for (int i = 0; i < mal.size(); i++) {
System.out.println(mal.get(i));
}
System.out.println(mal.isEmpty());
System.out.println(mal.remove("B"));
System.out.println(mal.size());*/
}
}
class Point {
int x, y;
public Point(int x, int y) {
this.x = x;
this.y = y;
}
public String toString() {
return "x = " + x + " y = " + y;
}
}
分享到:
相关推荐
在这个“ArrayList实现对产品CRUD”的项目中,我们将探讨如何利用面向对象编程(OOP)的思想来操作ArrayList,进行创建、读取、更新和删除(通常称为CRUD操作)产品对象。对于初学者来说,这是一个很好的实践案例,...
浅析ArrayList内部实现 ArrayList是Java集合框架中的一种常用数据结构,能够存储任意多个对象,并且可以自由扩展,弥补了数组的定长的缺陷。下面我们将深入探讨ArrayList的内部实现机理。 ArrayList的内部实现机理...
模拟ArrayList底层实现 在Java中,ArrayList是一种常用的集合类,提供了许多实用的方法来操作集合数据,而本文则尝试模拟ArrayList的底层实现,通过自定义集合实现类MyArrayList,来实现基本的集合操作。 模拟...
ArrayList是Java集合框架中常用的动态数组,它是List接口的一个实现,允许存储包括null在内的所有元素。ArrayList的主要特点是通过数组来存储元素,提供了丰富的操作方法,包括添加、删除、修改和查询等。下面是...
在这个场景中,我们将探讨如何利用ArrayList来实现ListView,以及如何添加编辑、新增、删除功能,以及在Activity间传递参数,同时还会涉及到ContextMenu和OptionsMenu的实现,以及长按事件的处理。 首先,我们需要...
用java自己实现的arrayList,比较详细,有助于初学者理解arrayList的基本概念和基础用法
大家好,我是Ziph! 学生成绩管理系统实例 实现一个学生成绩管理的简单系统。要求可以添加、删除、修改、查询成绩 创建界面相关的接口:将菜单中显示的内容定义成若干字符串常量,放入一个接口Menu中以便使用 ...
Java集合框架中,ArrayList是一种常见的集合实现类,用于存储和操作对象集合。ArrayList基于动态数组的数据结构,因此它能够提供自动扩容的功能,同时也能够快速地进行随机访问。本篇文档将深入探讨ArrayList的内部...
在这个ArrayList实现中,第一层散列可能是用来快速定位元素的位置,而第二层散列可能是为了处理散列冲突,确保每个元素都有一个唯一的索引。这种双层散列结构可以显著减少查找和插入的时间复杂度,使其接近O(1)。 ...
此方法是通过java提供的ArrayList方法对栈的实现;
自定义实现的ArrayList数据结构,有大量注释以及编写思路,帮助新手用Java语言来实现数据结构
自己写的ArrayList,请勿喷!
本篇将重点讲解如何利用ArrayList实现快速排序(Quick Sort)、归并排序(Merge Sort)和堆排序(Heap Sort)这三种经典的排序算法,并探讨它们的原理、优缺点以及在实际应用中的选择。 **快速排序(Quick Sort)**...
虽然JavaScript原生不支持ArrayList,但我们可以利用数组(Array)对象来实现类似的功能。下面将详细介绍如何使用JavaScript来实现基础的ArrayList功能,并探讨在没有参数重载(overload)的情况下如何处理方法的...
以上就是使用ArrayList实现用户信息管理的基本操作。然而,对于大型项目或频繁的增删改查操作,可能需要考虑使用更高效的数据结构,如HashMap(基于键值对,查找速度更快)或数据库来进行数据管理。在实际应用中,...
根据给定的信息,本文将详细解释如何在Java Server Pages (JSP)中使用`HttpSession`和`ArrayList`来实现一个简单的购物车程序。本文主要分为以下几个部分:商品类(`Goods`)的设计、购物车功能实现的具体步骤、以及...
标题中的“asp hashmap,arraylist实现”指的是在ASP(Active Server Pages)编程中使用HashMap和ArrayList这两种数据结构的具体应用。HashMap和ArrayList是.NET框架中常用的数据集合类,它们在处理和组织数据方面各...