1. HashSet集合
HashSet-JDK8版本及以后-面试常问
2. LinkedHashSet-Collection工具类
2.1 LinkedHashSet
2.2 Collection工具类
3. Map集合
3.1 Map接口介绍
3.2 Map 集合的遍历方式
3.2.1 三种方式介绍
package com.itheima.map;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
public class MapDemo3 {
public static void main(String[] args) {
HashMap<String, String> hm = new HashMap<>();
hm.put("张三", "北京");
hm.put("李四", "上海");
hm.put("王五", "成都");
hm.forEach((key, value) -> System.out.println(key + "---" + value));
System.out.println("-----------------------------");
hm.forEach((k,v) -> System.out.println(k + "---" + v));
}
private static void method2(HashMap<String, String> hm) {
// 1. 获取到所有的键值对对象
Set<Map.Entry<String, String>> entrySet = hm.entrySet();
// 2. 遍历set集合获取每一个键值对对象
for (Map.Entry<String, String> entry : entrySet) {
// 3. 通过键值对对象, 获取键和值
System.out.println(entry.getKey() + "---" + entry.getValue());
}
}
private static void method1(HashMap<String, String> hm) {
// 1. 获取到所有的键
Set<String> keySet = hm.keySet();
// 2. 遍历set集合, 获取每一个键
for (String key : keySet) {
// 3. 调用map集合的get方法, 根据键查找对应的值
String value = hm.get(key);
System.out.println(key + "---" + value);
}
}
}
3.2.2 Map 集合练习
package com.itheima.map;
import java.util.TreeMap;
import java.util.function.BiConsumer;
public class MapTest1 {
public static void main(String[] args) {
String info = "aababcabcdabcde";
// 1. 准备Map集合, 用于记录每个字符出现次数
TreeMap<Character, Integer> tm = new TreeMap<>();
// 2. 拆分字符串, 便于得到每个字符
char[] charArray = info.toCharArray();
// 3. 遍历数组, 获取每个字符
for (char c : charArray) {
// 4. 判断当前字符, 在集合中是否存在
if (!tm.containsKey(c)){
tm.put(c, 1);
}else {
tm.put(c, tm.get(c) + 1);
}
}
// 5. 准备StringBuilder
StringBuilder sb = new StringBuilder();
tm.forEach((key, value) -> sb.append(key).append("(").append(value).append(")"));
System.out.println(sb);
}
private static void method() {
String info = "ababc";
// 1. 准备map集合, 用于统计字符的次数
TreeMap<Character, Integer> tm = new TreeMap<>();
// 2. 拆分字符串
char[] charArray = info.toCharArray();
// 3. 遍历字符数组, 获取每一个字符
for (char c : charArray) {
// 4. 判断当前字符在集合中是否存在
if (!tm.containsKey(c)) {
// 不存在: 说明是第一次出现
tm.put(c, 1);
} else {
// 存在: 说明不是第一次出现, 获取旧值 + 1存回去
tm.put(c, tm.get(c) + 1);
}
}
// 5. 准备StringBuilder
StringBuilder sb = new StringBuilder();
tm.forEach((key, value) -> sb.append(key).append("(").append(value).append(")"));
System.out.println(sb);
}
}
package com.itheima.map;
import java.util.*;
public class MapTest2 {
public static void main(String[] args) {
HashMap<String, List<String>> hm = new HashMap<>();
ArrayList<String> list1 = new ArrayList<>();
Collections.addAll(list1, "南京市", "扬州市", "苏州市", "无锡市", "常州市");
ArrayList<String> list2 = new ArrayList<>();
Collections.addAll(list2, "武汉市", "孝感市", "十堰市", "宜昌市", "鄂州市");
ArrayList<String> list3 = new ArrayList<>();
Collections.addAll(list3, "成都市", "绵阳市", "自贡市", "攀枝花市", "泸州市");
hm.put("江苏省", list1);
hm.put("湖北省", list2);
hm.put("四川省", list3);
Set<Map.Entry<String, List<String>>> entrySet = hm.entrySet();
for (Map.Entry<String, List<String>> entry : entrySet) {
// 键: 省份
String key = entry.getKey();
System.out.print(key + "=");
// 值: 多个市名
List<String> list = entry.getValue();
for (int i = 0; i < list.size() - 1; i++) {
System.out.print(list.get(i)+", ");
}
System.out.println(list.get(list.size() - 1));
}
}
private static void method() {
HashMap<String, List<String>> hm = new HashMap<>();
ArrayList<String> list1 = new ArrayList<>();
Collections.addAll(list1, "南京市", "扬州市", "苏州市", "无锡市", "常州市");
ArrayList<String> list2 = new ArrayList<>();
Collections.addAll(list2, "武汉市", "孝感市", "十堰市", "宜昌市", "鄂州市");
ArrayList<String> list3 = new ArrayList<>();
Collections.addAll(list3, "成都市", "绵阳市", "自贡市", "攀枝花市", "泸州市");
hm.put("江苏省", list1);
hm.put("湖北省", list2);
hm.put("四川省", list3);
Set<Map.Entry<String, List<String>>> entrySet = hm.entrySet();
for (Map.Entry<String, List<String>> entry : entrySet) {
// 键: 省份名称
String key = entry.getKey();
System.out.print(key + "=");
// 值: 多个市名
List<String> list = entry.getValue();
for (int i = 0; i < list.size() - 1; i++) {
System.out.print(list.get(i) + ", ");
}
System.out.println(list.get(list.size() - 1));
}
}
}
注: 第一条红色字体为面试重点.