目录
一、Map
1、Map的常见API
2、map集合的三种遍历方式
3、HashMap
4、LinkedHashMap
5、TreeMap
一、Map
双列集合的特点
1、双列集合一次需要存一对数据,分别为键和值
2、键不能重复,值可以重复 1双列集合一次需要存一对数据,分别为键和值2键不能重复,值可以
重复
3、键和值是一一对应的,每一个键只能找到自己对应的值 3键和值是一一对应的,每一个键只能找到自己对应的值
4、键+值这个整体我们称之为“键值对”或者“键值对对象”,在Java中叫做“Entry对象” 4键+值这个整体我们称之为“键值对”或者“键值对对象”,在中叫做“Entry对象”
1、Map的常见API
Map是双列集合的顶层接口,它的功能是全部双列集合都可以继承使用的
方法名称 | 说明 |
v put(k key,v value) | 添加元素 |
v remove(object key) | 根据键删除键值对元素 |
void clear() | 移除所有的键值对元素 |
boolean containsKey(object key) | 判断集合是否包含指定的键 |
boolean containsValue(object value) | 判断集合是否包含指定的值 |
boolean isEmpty() | 判断集合是否为空 |
int size() | 集合的长度,也就是集合中键值对的个数 |
示例:
//创建map集合,
Map<String,String> map = new HashMap();
//添加元素
map.put("张三","123");
map.put("李四","456");
map.put("王五","789");
System.out.println(map);
System.out.println("_________________");
//根据键删除键值对元素
map.remove("张三");
System.out.println(map);
//判断集合是否包含指定的键
boolean flag = map.containsKey("张三");
System.out.println(flag);
//判断集合是否包含指定的值
boolean b = map.containsValue("456");
System.out.println(b);
//判断集合是否为空
boolean empty = map.isEmpty();
System.out.println(empty);
//集合的长度,也就是集合中键值对的个数
int size = map.size();
System.out.println(size);
//移除所有的键值对元素
map.clear();
System.out.println(map);
2、map集合的三种遍历方式
1、键找值
示例:
//创建map集合,
Map<String,String> map = new HashMap();
//添加元素
map.put("张三","123");
map.put("李四","456");
map.put("王五","789");
//获取所有的键放在单列集合里
Set<String> stringSet = map.keySet();
//遍历单列集合,得到每一个键
for (String key : stringSet) {
//通过键找到对应的值
String value = map.get(key);
System.out.println(key + "=" + value);
}
System.out.println("-------------");
//通过迭代器遍历
Iterator<String> iterator = stringSet.iterator();
while (iterator.hasNext()){
String key = iterator.next();
String value = map.get(key);
System.out.println(key + "=" + value);
}
System.out.println("-------------");
//通过Lambda表达式遍历
stringSet.forEach(s -> {
//通过键找到对应的值
String value = map.get(s);
System.out.println(s + "=" + value);
});
2、通过键值对
示例:
//创建map集合,
Map<String,String> map = new HashMap();
//添加元素
map.put("张三","123");
map.put("李四","456");
map.put("王五","789");
//获取所有键值对放入一个集合
Set<Map.Entry<String, String>> entries = map.entrySet();
//增强for遍历集合
for (Map.Entry<String, String> entry : entries) {
String key = entry.getKey();
String value = entry.getValue();
System.out.println(key + "=" + value);
}
System.out.println("-----------------");
//迭代器遍历
Iterator<Map.Entry<String, String>> iterator = entries.iterator();
while (iterator.hasNext()){
Map.Entry<String, String> next = iterator.next();
System.out.println(next);
}
System.out.println("-----------------");
//lambda表达式遍历
entries.forEach(Entry -> {
System.out.println(Entry);
});
3、lambda表达式
示例:
//创建map集合,
Map<String,String> map = new HashMap();
//添加元素
map.put("张三","123");
map.put("李四","456");
map.put("王五","789");
//匿名内部类
map.forEach(new BiConsumer<String, String>() {
@Override
public void accept(String s, String s2) {
System.out.println(s + "=" + s2);
}
});
System.out.println("_________________");
//简化
map.forEach((String key,String value)->{
System.out.println(key + "=" + value);
});
//简化
System.out.println("_________________");
map.forEach((key,value)->System.out.println(key + "=" + value));
3、HashMap
HashMap的特点
1、HashMap是Map里面的一个实现类。
2、没有特有方法,直接使用Map里面的方法就可以了。
3、特点都是由键决定的:无序、不重复、无索引
4、HashMap跟HashSet底层原理是一模一样的,都是哈希表结构
5、HashMap底层是哈希表结构的
6、依赖hashcode方法和equals方法保证键的唯一
7、如果键存储的是自定义对象,需要重写hashCode和equals方法如果值存储自定义对象,不需要
重写hashCode和equals方法
HashMap练习,统计投票数
//创建map集合,
Map<String,Integer> map = new HashMap();
//添加元素;定义四个景点
List<String> list = new ArrayList<>();
String [] array = {"A","B","C","D"};
//定义票数
Random random = new Random();
for (int i = 0; i < 40; i++) {
int index = random.nextInt(array.length);
list.add(array[index]);
}
for (String name : list) {
//判断当前景点是否在map集合中
if (map.containsKey(name)){
//存在
//先获取当前经典的票数
int count = map.get(name);
//景点票数加1
count++;
//再放回集合中
map.put(name,count);
}else {
//不存在
map.put(name,1);
}
}
//求最大值
int max = 0;
Set<Map.Entry<String, Integer>> entries = map.entrySet();
for (Map.Entry<String, Integer> entry : entries) {
int count = entry.getValue();
if (count>max){
max = count;
}
}
//判断那个景点票数最多,并打印
for (Map.Entry<String, Integer> entry : entries) {
int count = entry.getValue();
if (count == max){
System.out.println(entry.getKey());
}
}
System.out.println(map);
4、LinkedHashMap
由键决定:有序、不重复、无索引。
这里的有序指的是保证存储和取出的元素顺序一致
原理:底层数据结构是依然哈希表,只是每个键值对元素又额外的多了一个双链表的机制记录存储
的顺序。
示例:
//创建集合,
LinkedHashMap<String,Integer> linkedHashMap = new LinkedHashMap<>();
//添加元素
linkedHashMap.put("a",1);
linkedHashMap.put("a",2);
linkedHashMap.put("c",3);
linkedHashMap.put("d",4);
//打印集合
System.out.println(linkedHashMap);
5、TreeMap
TreeMap跟TreeSet底层原理一样,都是红黑树结构的。
由键决定特性:不重复、无索引、可排序
可排序:对键进行排序。
注意:默认按照键的从小到大进行排序,也可以自己规定键的排序规则
代码书写两种排序规则
1、实现Comparable接口,指定比较规则。
2、创建集合时传递Comparator比较器对象,指定比较规则。
示例:
//创建集合,
TreeMap<Integer,String> treeMap = new TreeMap<>(new Comparator<Integer>() {
@Override
public int compare(Integer o1, Integer o2) {
//o1表示当前要添加的元素
//o2表示已在红黑树存在的元素
//实现倒序
return o2-o1;
}
});
//添加元素
treeMap.put(5,"a");
treeMap.put(4,"b");
treeMap.put(3,"c");
treeMap.put(2,"d");
treeMap.put(1,"e");
//打印
System.out.println(treeMap);