说明都在注释:

package adt.array;

import java.util.Iterator;
import java.util.NoSuchElementException; /**
*
* @author 数据结构与算法分析
* @param <T> AnyType T 任何类型
*/
public class MyArrayList<T> implements Iterable<T>{ //集合初识长度
private static final int DEFAULT_CAPACITY = 10; //当前List数据长度
private int theSize; //底层数组集合
private T[] theItems; //长度
public int size() {
return theSize;
} //List判空
public boolean isEmpty() {
return size() == 0;
} /***
* 扩充长度
*/
public void trimToSize() {
ensureCapacity(size());
} /***
*根据下标获取数据,如果下标为负数或大于当前数组长度,抛出数组越界异常。
* @param idx
* @return
*/
public T get(int idx) {
if(idx < 0 || idx >= size()) {
throw new ArrayIndexOutOfBoundsException();
}
return theItems[ idx ];
} //初始化
public MyArrayList() {
doClear();
} //清除长度,将当前集合长度变为初始值
private void doClear() {
theSize = 0;
ensureCapacity(DEFAULT_CAPACITY);
} /***
* 如果当前需要扩充的长度小于当前数组长度,那么程序将不往下执行
* 否则获取当前数组,创造新的数组,新的数组长度根据newCapacity进行初始化,
* 然后将旧的数组赋给新的数组
* @param newCapacity
*/
@SuppressWarnings("unchecked")
private void ensureCapacity(int newCapacity) {
if(newCapacity < theSize)
return; T[] old = theItems; theItems = (T []) new Object[ newCapacity ];
for(int i = 0; i < size(); i++)
theItems[i] = old[i];
} //清空集合
public void clear() {
doClear();
} /**
* 更新数据,根据下标,判断下标是否越界,接着根据下标获取当前下标的数据进行覆盖
* @param idx
* @param newVal
* @return
*/
public T set(int idx, T newVal) {
if(idx < 0 || idx >= size()) {
throw new ArrayIndexOutOfBoundsException();
}
T old = theItems[ idx ];
theItems[idx] = newVal;
return old;
} //添加一个数据,在最后
public boolean add(T x) {
add(size(), x);
return true;
} /**
* 在上一个add方法中将数组长度传入,如果当前长度满了,那么扩充一倍(+1用于大小是0的情况)
* 接着将所有数据向后移一位,将输入插入到第一位index0,长度自增。
* @param idx
* @param x
*/
public void add(int idx,T x) { if(theItems.length == size())
ensureCapacity(size()*2+1); for(int i = theSize; i > idx; i--)
theItems[i] = theItems[i-1]; theItems[idx] = x; theSize++;
} /**
* 都差不多
* @param idx
* @return
*/
public T remove(int idx) {
T removeItem = theItems[idx];
for(int i = idx; i < size() -1; i++)
theItems[ i ] = theItems[ i +1 ]; theSize--;
return removeItem;
} //实现迭代器
@Override
public Iterator<T> iterator() {
return new ArrayListIterator();
} //具体实现
private class ArrayListIterator implements Iterator<T>{ private int current = 0; @Override
public boolean hasNext() {
return current < size();
} @Override
public T next() {
if(!hasNext())
throw new NoSuchElementException();
return theItems[current ++];
} public void remove() {
MyArrayList.this.remove(-- current);
}
} }
package adt.array;

public class MainTest {
//简单测试
public static void main(String[] args) {
MyArrayList<String> myArrayList = new MyArrayList<>();
for(int i = 0; i < 100; i++) {
myArrayList.add(RandomStr());
} myArrayList.forEach(str->{
System.out.println(str);
});
} public static String RandomStr() {
String strArr = "QaWsEdRfTgYhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM";
return strArr.substring((int)(Math.random()*strArr.length()));
} }

输出:

yHuJiKopLZzxXcCVbBbNnmM
cCVbBbNnmM
NnmM
DrFGyHuJiKopLZzxXcCVbBbNnmM
DrFGyHuJiKopLZzxXcCVbBbNnmM
AeDrFGyHuJiKopLZzxXcCVbBbNnmM
DrFGyHuJiKopLZzxXcCVbBbNnmM
yHuJiKopLZzxXcCVbBbNnmM
LZzxXcCVbBbNnmM
sEdRfTgYhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
QaWsEdRfTgYhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
jIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
UjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
AeDrFGyHuJiKopLZzxXcCVbBbNnmM
qPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
gYhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
zxXcCVbBbNnmM
M
zxXcCVbBbNnmM
BbNnmM
iKopLZzxXcCVbBbNnmM
fTgYhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
KopLZzxXcCVbBbNnmM
BbNnmM
ZzxXcCVbBbNnmM
bNnmM
JiKopLZzxXcCVbBbNnmM
gYhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
pLZzxXcCVbBbNnmM
lqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
CVbBbNnmM
ZzxXcCVbBbNnmM
qPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
BbNnmM
dRfTgYhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
eDrFGyHuJiKopLZzxXcCVbBbNnmM
YhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
gYhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
EdRfTgYhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
KopLZzxXcCVbBbNnmM
TgYhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
UjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
PwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
JiKopLZzxXcCVbBbNnmM
M
YhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
WsEdRfTgYhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
HuJiKopLZzxXcCVbBbNnmM
iKopLZzxXcCVbBbNnmM
uJiKopLZzxXcCVbBbNnmM
gYhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
LZzxXcCVbBbNnmM
nmM
xXcCVbBbNnmM
uJiKopLZzxXcCVbBbNnmM
WsEdRfTgYhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
XcCVbBbNnmM
rFGyHuJiKopLZzxXcCVbBbNnmM
opLZzxXcCVbBbNnmM
QaWsEdRfTgYhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
IkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
HuJiKopLZzxXcCVbBbNnmM
mM
bNnmM
BbNnmM
bNnmM
KopLZzxXcCVbBbNnmM
GyHuJiKopLZzxXcCVbBbNnmM
CVbBbNnmM
uJiKopLZzxXcCVbBbNnmM
EdRfTgYhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
WsEdRfTgYhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
CVbBbNnmM
fTgYhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
lqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
DrFGyHuJiKopLZzxXcCVbBbNnmM
mM
NnmM
dRfTgYhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
DrFGyHuJiKopLZzxXcCVbBbNnmM
BbNnmM
QaWsEdRfTgYhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
VbBbNnmM
DrFGyHuJiKopLZzxXcCVbBbNnmM
DrFGyHuJiKopLZzxXcCVbBbNnmM
cCVbBbNnmM
LZzxXcCVbBbNnmM
OlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
NnmM
PwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
KopLZzxXcCVbBbNnmM
NnmM
GyHuJiKopLZzxXcCVbBbNnmM
CVbBbNnmM
HuJiKopLZzxXcCVbBbNnmM
wAeDrFGyHuJiKopLZzxXcCVbBbNnmM
XcCVbBbNnmM
wAeDrFGyHuJiKopLZzxXcCVbBbNnmM
gYhUjIkOlqPwAeDrFGyHuJiKopLZzxXcCVbBbNnmM
PwAeDrFGyHuJiKopLZzxXcCVbBbNnmM

Java实现ArrayList的更多相关文章

  1. 解决springmvc报No converter found for return value of type: class java.util.ArrayList问题

    一.背景 最近闲来无事,想自己搭建一套Spring+SpringMVC+Mybatis+Mysql的环境(搭建步骤会在以后博客中给出),结果运行程序时,适用@ResponseBody注解进行返回Lis ...

  2. java 遍历arrayList的四种方法

    package com.test; import java.util.ArrayList;import java.util.Iterator;import java.util.List; public ...

  3. 初涉java库--ArrayList

    我的车就差一个轮子啦,造好轮子,我就飞上天与太阳肩并肩啦,想想都激动.什么你要自己造轮子,是不是傻,商店里不都是别人造好的吗,又好又方便,只需一点money,你没有money,那你只能做个安静的美男子 ...

  4. java集合-- arraylist小员工项目

    import java.io.*; import java.util.ArrayList; public class Emexe { public static void main(String[] ...

  5. java 16-2 ArrayList的练习2

      需求:去除集合中自定义对象的重复值(对象的成员变量值都相同 注意: 我们按照和字符串一样的操作,发现出问题了. 为什么呢? 我们必须思考哪里会出问题? 通过简单的分析,我们知道问题出现在了判断上. ...

  6. java 16-1 ArrayList的练习1

    需求: ArrayList去除集合中字符串的重复值(去掉相同的字符串) 分析: 第一种做法:创建一个新的空集合: A:创建1个具有相同字符串的集合 B:创建1个空的集合 C:遍历第一个集合里面的元素 ...

  7. Java.util.ArrayList详解

    java.util.ArrayList就是传说中的动态数组. 继承了关系,有此可看出ArrayList与list的collection的关系 public class ArrayList<E&g ...

  8. Java基础-ArrayList和LinkedList的区别

    大致区别:  1.ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构. 2.对于随机访问get和set,ArrayList觉得优于LinkedList,因为Lin ...

  9. java中ArrayList 、LinkList区别

    转自:http://blog.csdn.net/wuchuanpingstone/article/details/6678653 个人建议:以下这篇文章,是从例子说明的方式,解释ArrayList.L ...

  10. JAVA中ArrayList用法

    JAVA中ArrayList用法 2011-07-20 15:02:03|  分类: 计算机专业 |  标签:java  arraylist用法  |举报|字号 订阅     Java学习过程中做题时 ...

随机推荐

  1. 将两个列表合并为字典_其中一个列表为Key_一个列表为Value

    #定义两个列表 list1 = range(0,10) list2 = range(10,20) #合并为字典,调用dict(zip()) dict_name = dict(zip(list1,lis ...

  2. 前端每日实战:98# 视频演示如何用纯 CSS 创作一只愤怒小鸟中的绿猪

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/VBGWqX 可交互视频 此视频是可 ...

  3. ht-8 对arrayList中的自定义对象排序( Collections.sort(List<T> list, Comparator<? super T> c))

    package com.iotek.set; import java.util.ArrayList; import java.util.Collections; import java.util.Co ...

  4. 百度ueditor新增的将word内容导入到富文本编辑框的功能.

    如何做到 ueditor批量上传word图片? 1.前端引用代码 <!DOCTYPEhtmlPUBLIC"-//W3C//DTD XHTML 1.0 Transitional//EN& ...

  5. [NOIP2014]飞扬的小鸟[DP]

    [NOIP2014]飞扬的小鸟 ——!x^n+y^n=z^n 题目描述: Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画 ...

  6. BUUCTF |[0CTF 2016]piapiapia

    步骤: nickname[]=wherewherewherewherewherewherewherewherewherewherewherewherewherewherewherewherewhere ...

  7. matlab: undocumented sprintfc

    今天本想找一个类似于 R 中 paste 的 matlab 函数, 结果在 stackoverflow 上找到一个叫 sprintfc 的函数 (http://stackoverflow.com/qu ...

  8. zookeeper centos分布式安装使用

    1. 请先安装jdk和下载zookeeper.ssh免密登录请自行配置.大家可以到官网下载或我的网盘. 网盘地址: 共3台机器c0,c1,c2 192.168.132.148 c0192.168.13 ...

  9. Git是目前世界上最先进的分布式版本控制系统(没有之一)。

    http://zhidao.baidu.com/link?url=NSYPiSvtGTMoqMA9vt68FRRF8WbfYVmwWeMh47_2lkp0K3jFMl--1Co1tg1R4VshTQV ...

  10. stl vector创建二维数组

    vector<vector<); for (auto it = v.begin(); it != v.end(); it++) { ; (*it).reserve();//预留空间为5,但 ...