Java的集合主要由两个接口派生出来,一个是Collection一个是Map,本章只记录Collection常用集合
集合只能存储引用类型数据,不能存储基本类型数据
集合类是一种特别有用的工具类,它可以存放数量不等的对象,实现常用的数据结构,如栈,队列等。除此之外,Java集合还可用于保存具有映射关系的关联数组。简单的来说,Java集合就是一个容器,可以把多个对象丢进该容器中。
Collection从父类接口Iterable中继承了抽象方法iterator()
所有Collection接口的实现类都需要重写抽象方法iterator()
---所有Collection集合都是可迭代的。
import java.lang.reflect.Constructor; import java.util.ArrayList; import java.util.Collection; import java.util.function.Consumer; /** * @ClassName ArrayListExample * @projectName: object1 * @author: Zhangmingda * @description: XXX * date: 2021/4/8. */ public class ArrayListExample { public static void main(String[] args) { Collection persons = new ArrayList(); System.out.println(persons.size());//判断集合元素核数 persons.add("帅哥"); persons.add("美女"); persons.add("大爷"); //添加元素 System.out.println(persons); Collection persons2 = new ArrayList(); persons2.add("QIQI"); persons2.add("hh"); persons.add(persons2); persons.addAll(persons2); //集合合并 System.out.println(persons); System.out.println(persons.contains("hh")); //判断是否存在元素 System.out.println(persons.containsAll(persons2));//判断是否存在另一个集合 System.out.println(persons.isEmpty()); //判断是否为空 System.out.println(persons.size()); persons.clear();//清空集合 System.out.println(persons.size()); persons.forEach(new Consumer() { @Override public void accept(Object o) { System.out.println(o); } }); } }
import java.util.ArrayList; import java.util.Collection; import java.util.function.Consumer; /** * @ClassName ArrayListLambdaExample * @projectName: object1 * @author: Zhangmingda * @description: XXX * date: 2021/4/8. */ public class ArrayListLambdaExample { public static void main(String[] args) { Collection persons = new ArrayList(); System.out.println(persons.size());//判断集合元素核数 persons.add("帅哥"); persons.add("美女"); persons.add("大爷"); //添加元素 //查找需要传入的匿名类对象 persons.forEach(new Consumer() { @Override public void accept(Object o) { System.out.println(o); } }); //使用lambda方式遍历 persons.forEach(o -> System.out.println(o)); } }
14-1-1 List接口继承了Collection
特点:有序,可重复
有序:存储顺序与添加顺序一样
可重复:可以存储重复的数据,List为每个元素指定了索引值,增加了针对索引值的操作
实现类:
ArrayList:底层数据结构是数组,访问快、添加删除慢,初始化容量10,扩容1.5倍
Vector:底层也是数组,是线程安全的,初始化容量10,扩容2.0倍
LinkedList:底层数据结构是双向链表,访问慢、添加删除效率高
双向链表?:...
ArrayList 实现 Collection接口 示例:
//1、实际应用中,一个集合一般只存储同一类型的数据,可以再定义集合时通过泛型指定存储元素的数据类型
//在定义集合存储String字符串,只需要在接口名Collection后面使用尖括弧<String> 泛型指定存储String
Collection<String> collection = new ArrayList<>();
collection.add("aa");
collection.add("bb");
collection.add("aa");
collection.add("bb");
collection.add("cc");
System.out.println(collection);
//2、添加非泛型指定的数据类型,会语法错误
// collection.add(123);
//
//3、遍历集合中的每一个元素,快捷匹配itco
//hasNext()判断游标后面是否还有元素
//.next()返回当前游标所在的下一个元素值
for (Iterator<String> iterator = collection.iterator(); iterator.hasNext(); ) {
String next = iterator.next();
System.out.println(next);
}
//3、简单易理解的遍历写法
Iterator<String> iterator = collection.iterator();
while (iterator.hasNext()){
System.out.println(iterator.next());
}
//4、删除元素
//.remove()只能删除第一个匹配的元素
collection.remove("aa");
System.out.println(collection);
//5、要遍历到需要删除的元素使用迭代器删除
for (Iterator<String> stringIterator = collection.iterator(); stringIterator.hasNext(); ) {
//String next = stringIterator.next();
if ("aa".equals(stringIterator.next())){
stringIterator.remove();
}
}
System.out.println(collection);
ArrayList 实现 List接口 示例:
List<String > list = new ArrayList<>();
list.add("a");
list.add("bb");
list.add("ccc");
list.add("bb");
list.add("ff");
list.add("ccc");
System.out.println(list);
//1、list 为每个元素指定了索引值
list.add(0,"ShaBi");
System.out.println(list);
//2、返回指定位置的元素
System.out.println(list.get(0));
//3、修改指定位置的元素
list.set(1,"HaHa");
System.out.println(list);
//4、删除指定位置的元素
list.remove(1);
System.out.println(list);
//5、可以for循环遍历list集合
for (int i = 0; i < list.size(); i++) {
System.out.println(list.get(i));
}
//6、List在JDK8中新增了sort(Comparator) 排序功能
list.sort(new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
return o1.compareTo(o2);
}
});
System.out.println(list);
注意:
ArrayList 对象实现类:
ArrayList<String> arrayList = new ArrayList<>();
arrayList.add("e23");
arrayList.add("e24");
System.out.println(arrayList);
System.out.println(arrayList.contains("e23"));
Vector
Vector<String> vector = new Vector<>();
vector.add("abc");
vector.add("Hello");
vector.add("World");
System.out.println(vector);
vector.remove("Hello");
System.out.println(vector);
注意:
LinkedList
注意理解双向链表的添加删除快访问慢的原理