集合
1.继承体系
- Collection 单列集合
- Map 双列集合
2.Collection接口
2.1 概述
- 单列集合的顶层接口,它表示一组对象,这些对象也被称为Collection的元素
- JDK不提供此接口的任何直接实现,它提供更具体的子接口(如Set和List)实现
2.2 创建Collection集合
public class CollectionDemo2 {
public static void main(String[] args) {
Collection<String> collection = new ArrayList<>();
// - boolean add(E e)添加元素
collection.add("aaa");
collection.add("bbb");
collection.add("ccc");
}
}
public class CollectionDemo2 {
public static void main(String[] args) {
List<String> list = new ArrayList<>();
// - boolean add(E e)添加元素
list.add("aaa");
list.add("bbb");
list.add("ccc");
}
}
2.3 Collection集合常用的方法
public class CollectionDemo2 {
public static void main(String[] args) {
Collection<String> collection = new ArrayList<>();
// - boolean add(E e)添加元素
collection.add("aaa");
collection.add("bbb");
collection.add("ccc");
System.out.println(collection); // [aaa, bbb, ccc]
//- boolean remove(Object o)从集合中移除指定的元素
boolean result = collection.remove("aaa");
boolean result2 = collection.remove("ddd");
System.out.println(result); // true
System.out.println(result2); // false
System.out.println(collection); // [bbb, ccc]
//- boolean removeif(Object o) 根据条件进行删除
// 注意事项,removeif括号中可以使用lambda表达式
collection.removeIf((String s)->{
return s.length() == 3; // 删除字符串长度为三的字符串
});
System.out.println(collection);// []
collection.add("aaa");
collection.add("bbb");
collection.add("ccc");
System.out.println(collection); // [aaa, bbb, ccc]
//- void clear()清空集合
collection.clear();
System.out.println(collection); // []
//- boolean contains(Object o)判断集合中是否存在指定的元素
collection.add("aaa");
System.out.println(collection.contains("aaa")); // true
System.out.println(collection.contains("ddd")); // false
//- boolean isEmpty()判断集合是否为空
System.out.println(collection.isEmpty()); // false
//- int size0集合的长度,也就是集合中元素的个数
System.out.println(collection.size()); // 1
}
}
2.4 Iterator
迭代器,集合专业遍历方式,是一个接口,我们无法直接使用,需要使用Iterator接口的实现类对象,获取实现类的方式比较特殊,Collection接口中有一个方法,叫Iterator(),这个方法返回的就是迭代器的实现类对象,
Iterator<e> iterator()
返回再此 collection 的元素上进行的迭代器。
2.4.1 使用步骤
- 使用集合中的方法iterator()获取迭代器的实现类对象,使用Iterator接口接收(多态)
- 使用Iterator接口当中的方法hasNext判断下还有没有下一个元素
- 使用Iterator接口中的方法next取出集合的下一个元素
2.4.2 常用方法
- public e next():返回迭代的下一个元素,取出元素后将迭代器往后移动一个索引
- public boolean hasNext():如果仍有元素可以迭代,则返回true
- default void remove():从底层集合中删除迭代器返回的最后一个元素(指向谁删除谁)
public class CollectionDemo3 {
public static void main(String[] args) {
Collection<String> coll = new ArrayList<>();
//添加元素:
coll.add("11");
coll.add("22");
coll.add("33");
//1.使用集合中的方法iterator()获取迭代器的实现类对象,使用Iterator接口接收(多态)
//注意:Iterator<E>接口也是由泛型的,迭代器的泛型跟着集合走,集合是什么泛型,迭代器就是什么泛型
Iterator<String> it = coll.iterator();
//2. 使用Iterator接口当中的方法hasNext判断下还有没有下一个元素
//没有元素,在取出元素会抛出NoSuchElementException没有元素异常
while(it.hasNext()){
//3. 使用Iterator接口中的方法next取出集合的下一个元素
String e = it.next();
System.out.println(e);
}
Iterator<String> it2 = coll.iterator();
while(it2.hasNext()){
String e = it2.next();
if("11".equals(e)){
it.remove();
}
}
System.out.println("--------------------------------");
for(Iterator<String> it3 = coll.iterator();it3.hasNext();){
String e = it3.next();
System.out.println(e);
}
}
}
打印结果
2.5 继承体系
- List 可重复
- Set 不可重复