如果要存放多个对象,可以使用数组,但是数组会有长度的限制,会出现不够用或者是浪费的情况。
为了解决数组的局限性引入了容器的概念,最常用的容器就是ArrayList。
容器的容量会随着对象的增加,自动增长,不用担心超限的情况发生。
ArrayList allWork = new ArrayList(); //定义格式
allWork.add(new SchoolWork("math")); //直接add对象,把对象加在最后面
allWork.add(1, "math"); //在指定位置增加对象
System.out.println(allWork.contains("math")); //判断是否存在math,存在输出true,反之false
System.out.println(allWork.get(1)); //超限则会报错
System.out.println(allWork.indexOf("math")); //输出math的位置下标
allWork.remove(1); //删除下标1的对象
allWork.remove("math"); //直接指定删除对象删除
allWork.set(1, "english"); //把下标1的元素替换为english
System.out.println(allWork.size()); //输出大小
SchoolWork arr[] = (school[])allWork.toArray(new SchoolWork[]{});
//假设有allWork和threeWork两个容器,并且threeWork中已有对象
allWork.addAll(threeWork); //将threeWork中的对象都添加到allWork中
allWork.clear();
ArrayList实现了List接口,通常会把引用声明为List接口类型(导入java.util.List)
List allWork = new ArrayList();
不指定范型的容器可以存放任何类型的元素
指定了范型的容器只能存放指定类型的元素及其子类
List<SchoolWork> allWork = new ArrayList<SchoolWork>(); //为了不出现编译警告,前后都使用范型
List<SchoolWork> allWork = new ArrayList<>(); //jdk7提供了简单的缩写
for (int i = 0; i < allWork.size(); i++) {
SchoolWork h = allWork.get(i);
System.out.println(h);
}
Iterator<SchoolWork> it= allWork.iterator();
//从最开始的位置判断"下一个"位置是否有数据
//如果有就通过next取出来,并且把指针向下移动
//直到"下一个"位置没有数据
while(it.hasNext()){
SchoolWork h = it.next();
System.out.println(h);
}
//迭代器的for写法
System.out.println("--------使用for的iterator-------");
for (Iterator<SchoolWork> iterator = allWork.iterator(); iterator.hasNext();) {
SchoolWork work = (SchoolWork) iterator.next();
System.out.println(work);
}
很多程序员的首选,但存在不足之处:
无法用来进行ArrayList的初始化
无法得知当前是第几个元素了,当需要只打印单数元素的时候就做不到了
for (SchoolWork h : allWork) {
System.out.println(h);
}
原文:https://www.cnblogs.com/zx224569/p/12968704.html