一、集合的体系分类
分为单列集合,双列集合。和数组相比,大小可变更加灵活。
List集合有序可重复有索引,Vector线程安全。
Set集合无序不重复无索引,但带Linked则有序。
Map是无序不重复无索引的。
带Tree则是排序集合。也就是说,这种集合里面的元素都是按照一定的规则的顺序存放的,这个规则也可以由我们定。
二、集合常用的方法
Collection
以ArrayList为例,主要有add,remove,contains,clear,isEmpty,size,toArray等。
List<String> list = new ArrayList<>();
//添加元素
list.add("张三");
list.add("李四");
list.add("王五");
//删除元素(根据索引操作是List特有的)
list.add(2,"钱七");//按索引添加
list.set(1,"赵六");//按索引修改
list.get(2);//按索引取出元素
list.remove(1);//按索引删除元素
list.remove("张三");
//判断是否包含某个元素,返回布尔类型的值
list.contains("张三");
//清空集合
list.clear();
//判断是否为空
list.isEpmty();
//返回集合元素个数
list.size();
//把集合元素存到数组中
list.toArray();
Map
以HashMap为例,常用方法和Collection集合思路上大同小异。集合增加元素为put。putAll合并集合。get(key)根据键找值。着重说一下keySet,entrySet。
Map<String,Integer> maps = new HashMap<>();
maps.put("岳麓山",10);
maps.put("橘子洲头",15);
maps.put("桃花岭",8);
// 获取全部键的集合
Set<String> keys = maps.keySet();
// 获取全部值的集合
Collection<Integer> values = maps.values();
//遍历map集合
Set<Map.Entry<String, Integer>> entries = maps.entrySet();
for(Map.Entry<String,Integer> entry :entries){
String key = entry.getKey();
int value = entry.getValue();
System.out.println(key + "->" + value);
}
三、Collectinos
是操作集合的工具类,有很多方法。例如Collections.addAll(list,…)批量添加元素,Collections.sort(list)给集合排序,Collections.shuffle(list)打乱集合元素的顺序。
List<String> list = new ArrarList<>();
Conllections.addAll(list,"周依","邹迩","舟莎","宙斯");
Conllections.shuffle(list);
Conllections.sort(list);//按默认规则排序
//可以自定义规则
Collections.sort(list, new Comparator<E>() {
@Override
public int compare(E o1, E o2) {
return Double.compare(o1.getXXX(), o2.getXXX());
}
});