Collection接口包含List接口与Set接口
——List 元素有序(存储顺序和取出顺序一致),元素可以重复
实现List接口的三个具体类有 ArrayList,vector,LinkedList
——Set 元素唯一,且元素无序(存储顺序和取出顺序不一致)
实现Set接口的两个具体类有: HashSet,TreeSet
Map集合
Map接口和Collection接口的不同:
Map集合的特点:
Map集合的功能:
这里使用的具体实现类是HashMap类,其特点是
map集合的遍历
方式一、根据键找值,借助Set keySet()遍历
方式二、根据键值对对象找键和值
当自定义类的对象传入map集合时,应该重写equals和hashcode方法
LinkedHashMap
TreeMap
例1 key值为String类型时
例2 key值为自定义的类的时候
一、用学生类Student实现Comparable接口的方式排序
二、用排序器Comparator实现排序
TreeMap实例
Map接口不属于Collection接口
Map接口和Collection接口的不同:
它们两个不存在继承关系,都是属于java.util包下面的平级关系
Map集合存储的元素都是成对出现的,Map元素的键是唯一的,值是可以重复。把这样的元素理解为:夫妻对
Collection集合存储的元素都是单独出现的,Collection接口下面的Set是元素唯一的, List集合中元素是可以重复的。
这样的单独出现的元素,可以理解为单身
Map集合的特点:
将键映射到值的对象、
key和value可以是任意的引用类型的数据
一个映射不能包含重复的键(map集合的key值不能重复)
每个键最多可以映射到一个值(每个键值对只有一个key值,一个value值)
同样的值可以对应多个不同的键(不同的键值对可以拥有相同的value值)
Map集合的功能:
1、添加功能: put(K key,V value)将指定的值与该映射中的指定键相关联
2、删除功能:
remove(Object key)如果存在,从该map集合中删除一个键的映射
void clear()从该map集合中删除所有的映射
3、长度功能:int size()返回此地图中键值映射的数量
Map<String,Object> map = new HashMap<>();
map.put("name", "zs");
map.put("sex", "boy");
map.put("age", 21);
//问题,如何键相同,值如何处理(覆盖了)
map.put("name", "ww");
map.put("score", 21);
System.out.println(map);
3种遍历方式
//遍历方式3种
//1.获取所有的keys
System.out.println("======所有的键值对========");
Set<String> keys = map.keySet();
for (String key : keys) {
System.out.println(key);
}
//2.获取所有的values
System.out.println("=====所有的values========");
Collection<Object> values = map.values();
for (Object object : values) {
System.out.println(object);
}
//3.获取所有的键值对
System.out.println("=====所有的键值对========");
Set<Entry<String, Object>> entrySet = map.entrySet();
for (Entry<String, Object> entry : entrySet) {
System.out.println(entry.getKey()+"="+entry.getValue());
}