1、List集合的特点
- 有序集合、有序的序列,用户可以精准的控制元素插入的位置
- 通过索引访问元素
- 可以搜索元素
- 与
Set
不同,List
允许重复的元素存在
2、List集合特有的方法
- add(索引,元素)
- remove(索引):返回的是被删除的索引
- get(索引):获取指定位置的元素
3、List集合的遍历
3.1迭代器遍历
- 和Collection一样可以使用迭代器遍历
注意迭代器遍历过程中修改元素,会造成并发修改异常
3.2 for循环遍历
- 因为有下标,所以可以使用for循环遍历
for循环遍历,遍历过程中修改元素,不会造成并发修改异常
3.3 增强for循环遍历
4、列表迭代器(ListIterator )
- 它是list集合特有的迭代器
- 通过list集合的
listIterator()
方法得到一个列表迭代器 - 允许在任意方向遍历
- 在迭代期间修改列表,并获取位置
常用方法
方法名 | 说明 |
---|---|
E next(); | 返回迭代中的下一个元素 |
boolean hasNext(); | 判断是否有下一个元素,有则返回true,无则false |
E previous(); | 返回迭代器中的上一个元素 |
boolean hasPrevious(); | 判断是否有上一个元素,有则返回true,无则false |
void add(E e); | 将指定的元素插入列表 |
void remove(); | 从列表中删除由 next()或 previous()返回的最后一个元素(可选操作) |
void set(E e); | 用指定的元素替换由 next()或 previous()返回的最后一个元素(可选操作) |
public class Demo {
public static void main(String[] args) {
//建立List集合
List<String> s=new ArrayList<>();
//添加集合元素
s.add("鸡");
s.add("你");
s.add("美");
//建立List迭代器(ListIterator)
ListIterator<String> lit = s.listIterator();
// E next(); 返回迭代中的下一个元素
// boolean hasNext(); 判断是否有下一个元素,有则返回true,无则false
while(lit.hasNext()){
String ss = lit.next();
if (ss.equals("你")){
//void add(E e); 将指定的元素插入列表(注意是lit调用add方法哦,是往!集合!中添加)
lit.add("太");
}
// System.out.println(ss);//用迭代器内部输出是没有添加"太"元素的
}
System.out.println(s);
System.out.println("=================================");
// E previous(); 返回迭代器中的上一个元素
// boolean hasPrevious(); 判断是否有上一个元素,有则返回true,无则false
while (lit.hasPrevious()){//逆向索引(从后往前)
String sss = lit.previous();
if (sss.equals("鸡")){
// void remove();从列表中删除由 next()或 previous()返回的最后一个元素(可选操作)
lit.remove();
}
// System.out.println(sss);用迭代器内部输出是没有删除"鸡"元素的
}
System.out.println(s);
System.out.println("=================================");
//通常我们使用普通for多
for (int i = 0; i < s.size(); i++) {
String s1 = s.get(i);
System.out.println(s1);
}
}
}
输出: