参考
使用数组的局限性
一个长度是10的数据:Hero[] heroArr=new Hero[10];
如果用数组存放数据,那么超过10的数据就放不下了
如果数据不足10个,那么数组空间就浪费了
package collection; import charactor.Hero; public class TestCollection { public static void main(String[] args) { //数组的局限性 Hero heros[] = new Hero[10]; //声明长度是10的数组 //不用的数组就浪费了 //超过10的个数,又放不下 heros[0] = new Hero("盖伦"); //放不下要报错 heros[20] = new Hero("提莫"); } }
ArrayList存放对象
ArrayList实现了接口List
常见的写法会把引用声明为接口List类型注意:是java.util.List,而不是java.awt.ListList heros =
new
ArrayList();
为了解决数组的局限性,引入容器类的概念。 最常见的容器类就是
ArrayList "capacity"会随着对象的增加,自动增长 只需要不断往容器里增加英雄即可,不用担心会出现数组的边界问题。package collection; import java.util.ArrayList; import charactor.Hero; public class TestCollection { @SuppressWarnings("rawtypes") public static void main(String[] args) { //容器类ArrayList,用于存放对象 ArrayList heros = new ArrayList(); heros.add( new Hero("盖伦")); System.out.println(heros.size()); //容器的容量"capacity"会随着对象的增加,自动增长 //只需要不断往容器里增加英雄即可,不用担心会出现数组的边界问题。 heros.add( new Hero("提莫")); System.out.println(heros.size()); } }
增加
add 有两种用法第一种是直接add对象,把对象加在最后面heros.add(new Hero("hero " + i));第二种是在指定位置加对象heros.add(3, specialHero);
获取指定位置的对象
通过get获取指定位置的对象,如果输入的下标越界,一样会报错
package collection; import java.util.ArrayList; import charactor.Hero; public class TestCollection { public static void main(String[] args) { ArrayList heros = new ArrayList(); // 初始化5个对象 for (int i = 0; i < 5; i++) { heros.add(new Hero("hero " + i)); } Hero specialHero = new Hero("special hero"); heros.add(specialHero); //获取指定位置的对象 System.out.println(heros.get(5)); //如果超出了范围,依然会报错 System.out.println(heros.get(6)); } }
获取对象所处的位置
indexOf用于判断一个对象在ArrayList中所处的位置与一样,判断标准是对象是否相同,而非对象的name值是否相等
package collection; import java.util.ArrayList; import charactor.Hero; public class TestCollection { public static void main(String[] args) { ArrayList heros = new ArrayList(); // 初始化5个对象 for (int i = 0; i < 5; i++) { heros.add(new Hero("hero " + i)); } Hero specialHero = new Hero("special hero"); heros.add(specialHero); System.out.println(heros); System.out.println("specialHero所处的位置:"+heros.indexOf(specialHero)); System.out.println("新的英雄,但是名字是\"hero 1\"所处的位置:"+heros.indexOf(new Hero("hero 1"))); }}
删除
remove用于把对象从ArrayList中删除
remove可以根据下标删除ArrayList的元素heros.remove(2); 也可以根据对象删除heros.remove(specialHero);
替换
set用于替换指定位置的元素
package collection; import java.util.ArrayList; import charactor.Hero; public class TestCollection { public static void main(String[] args) { ArrayList heros = new ArrayList(); // 初始化5个对象 for (int i = 0; i < 5; i++) { heros.add(new Hero("hero " + i)); } Hero specialHero = new Hero("special hero"); heros.add(specialHero); System.out.println(heros); System.out.println("把下标是5的元素,替换为\"hero 5\""); heros.set(5, new Hero("hero 5")); System.out.println(heros); }}
获取大小
size 用于获取ArrayList的大小
转换为数组
toArray可以把一个ArrayList对象转换为数组。需要注意的是,如果要转换为一个Hero数组,那么需要传递一个Hero数组类型的对象给toArray(),这样toArray方法才知道,你希望转换为哪种类型的数组,否则只能转换为Object数组
Hero hs[] = (Hero[])heros.toArray(new Hero[]{});
package collection; import java.util.ArrayList; import charactor.Hero; public class TestCollection { public static void main(String[] args) { ArrayList heros = new ArrayList(); // 初始化5个对象 for (int i = 0; i < 5; i++) { heros.add(new Hero("hero " + i)); } Hero specialHero = new Hero("special hero"); heros.add(specialHero); System.out.println(heros); Hero hs[] = (Hero[])heros.toArray(new Hero[]{}); System.out.println("数组:" +hs); }}
把另一个容器所有对象都加进来
package collection; import java.util.ArrayList; import charactor.Hero; public class TestCollection { public static void main(String[] args) { ArrayList heros = new ArrayList(); // 初始化5个对象 for (int i = 0; i < 5; i++) { heros.add(new Hero("hero " + i)); } System.out.println("ArrayList heros:\t" + heros); //把另一个容器里所有的元素,都加入到该容器里来 ArrayList anotherHeros = new ArrayList(); anotherHeros.add(new Hero("hero a")); anotherHeros.add(new Hero("hero b")); anotherHeros.add(new Hero("hero c")); System.out.println("anotherHeros heros:\t" + anotherHeros); heros.addAll(anotherHeros); System.out.println("把另一个ArrayList的元素都加入到当前ArrayList:"); System.out.println("ArrayList heros:\t" + heros); }}
清空
clear 清空一个ArrayList,heros.clear();
做一个一样的练习,但是不使用字符数组,而是使用ArrayList来实现
package Test; import java.util.ArrayList; /** * @Auther: 李景然 * @Date: 2018/5/23 15:56 * @Description:做一个一样的MyStringBuffer练习,但是不使用字符数组,而是使用ArrayList来实现 */ public class MyStringBufferTest{ ArrayList sb = new ArrayList(); public MyStringBufferTest() { } public MyStringBufferTest(String string) { this.append(string); } public static void main(String[] args) { MyStringBufferTest sb = new MyStringBufferTest("there light"); System.out.println(sb); sb.insert(0, "let "); System.out.println(sb); sb.insert(10, "be "); System.out.println(sb); sb.insert(0, "God Say:"); System.out.println(sb); sb.append("!"); System.out.println(sb); sb.append('?'); System.out.println(sb); sb.reverse(); System.out.println(sb); sb.reverse(); System.out.println(sb); sb.delete(0, 4); System.out.println(sb); sb.delete(4); System.out.println(sb); } public void append(String str) { this.insert(sb.size(), str); } public void append(char c) { this.insert(sb.size(), c); } public void insert(int pos, char b) { sb.add(pos, String.valueOf(b)); } public void insert(int pos, String b) { if (pos < 0 || pos > sb.size()) throw new RuntimeException("角标越界"); if (b.equals("")) throw new IllegalArgumentException("请勿输入空字符串"); for (int i = pos; i < b.length(); i++) { sb.add(i, b.charAt(i - pos)); } } public void delete(int start) { this.delete(start, sb.size()); } public void delete(int start, int end) { for (int i = start; i < end; i++) { sb.remove(i); } } public void reverse() { for (int i = 0; i <= sb.size() - i; i++) { char c = (char) sb.indexOf(i); sb.set(i, sb.indexOf(sb.size() - i)); sb.set(sb.size() - i, c); } } public int length() { return sb.size(); } public String toString() { return sb.toString(); } }
![](https://images2018.cnblogs.com/blog/1042779/201805/1042779-20180523155239642-1572753574.png)
泛型 Generic
不指定泛型的容器,可以存放任何类型的元素
指定了泛型的容器,只能存放指定类型的元素以及其子类//对于不使用泛型的容器,可以往里面放英雄,也可以往里面放物品 List heros = new ArrayList(); heros.add(new Hero("盖伦")); //本来用于存放英雄的容器,现在也可以存放物品了 heros.add(new Item("冰杖"));
遍历
用for循环遍历
for (int i = 0; i < heros.size(); i++) { Hero h = heros.get(i); System.out.println(h); }
迭代器遍历
package collection; import java.util.ArrayList;import java.util.Iterator;import java.util.List; import charactor.Hero; public class TestCollection { public static void main(String[] args) { Listheros = new ArrayList (); //放5个Hero进入容器 for (int i = 0; i < 5; i++) { heros.add(new Hero("hero name " +i)); } //第二种遍历,使用迭代器 System.out.println("--------使用while的iterator-------"); Iterator it= heros.iterator(); //从最开始的位置判断"下一个"位置是否有数据 //如果有就通过next取出来,并且把指针向下移动 //直达"下一个"位置没有数据 while(it.hasNext()){ Hero h = it.next(); System.out.println(h); } //迭代器的for写法 System.out.println("--------使用for的iterator-------"); for (Iterator iterator = heros.iterator(); iterator.hasNext();) { Hero hero = (Hero) iterator.next(); System.out.println(hero); } } }
用增强型for循环
使用增强型for循环可以非常方便的遍历ArrayList中的元素,这是很多开发人员的首选。
不过增强型for循环也有不足:无法用来进行ArrayList的初始化无法得知当前是第几个元素了,当需要只打印单数元素的时候,就做不到了。 必须再自定下标变量。for (Hero h : heros) { System.out.println(h); }
利用迭代器可以删除ArrayList中的元素
Iteratori=hList.iterator(); while (i.hasNext()){ Hero h=i.next(); i.remove();//这样会把ArrayList中的数据删除光 }
下一节LinkedList