Day11-Java进阶-HashSet集合LinkedHashSet-Collection工具类Map集合

embedded/2024/10/18 22:37:42/

1. HashSet集合

HashSet-JDK8版本及以后-面试常问

2. LinkedHashSet-Collection工具类

2.1 LinkedHashSet

2.2 Collection工具类

3. Map集合

3.1 Map接口介绍

3.2 Map 集合的遍历方式

3.2.1 三种方式介绍

java">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 集合练习

java">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. 准备StringBuilderStringBuilder 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. 准备StringBuilderStringBuilder sb = new StringBuilder();tm.forEach((key, value) -> sb.append(key).append("(").append(value).append(")"));System.out.println(sb);}
}

java">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));}}
}

注: 第一条红色字体为面试重点.


http://www.ppmy.cn/embedded/10061.html

相关文章

Centos7.9云计算CloudStack4.15 高级网络配置(3)

上两章的文章都是用的CloudStack的基本网络&#xff0c;这一篇我们来介绍CloudStack的高级网络&#xff0c;这里虚拟机用的是自己配置的内部网络&#xff0c;通过nat方式到物理网络。按照第一篇的文章&#xff0c;安装管理服务器和计算服务器。 并且在管理服务器配置好如下的全…

ospf的工作过程和特点

OSPF&#xff08;Open Shortest Path First&#xff09;是一种内部网关协议&#xff08;Interior Gateway Protocol&#xff09;&#xff0c;用于路由器之间交换路由信息&#xff0c;从而在自治系统内计算数据的最短传输路径。其工作原理基于链路状态路由算法&#xff0c;具体过…

CountDownLatch倒计时器源码解读与使用

&#x1f3f7;️个人主页&#xff1a;牵着猫散步的鼠鼠 &#x1f3f7;️系列专栏&#xff1a;Java全栈-专栏 &#x1f3f7;️个人学习笔记&#xff0c;若有缺误&#xff0c;欢迎评论区指正 目录 1. 前言 2. CountDownLatch有什么用 3. CountDownLatch底层原理 3.1. count…

项目大集成

一 keeplived 高可用 192.168.11.11nginx keeplived192.168.11.12nginx keeplived 两台均编译安装服务器 1 主服务器修改文件&#xff1a; 2 备服务器修改文本 scp keepalived.conf 192.168.11.12:/etc/keepalived/ 3 给主服务器添加虚拟ip ifconfig ens33:0 192.168…

milvus服务安装bash脚本指令理解

下拉镜像&#xff1a;docker pull milvusdb/milvus:v2.4.0-rc.1下载文件&#xff1a;https://hub.yzuu.cf/milvus-io/milvus/blob/master/scripts/standalone_embed.sh安装启动&#xff1a;bash standalone_embed.sh start详细解释下这段代码&#xff1a;wait_for_milvus_runni…

数组的排序算法

1.冒泡排序法 原理如下&#xff1a;每次比较数组中相邻的两个数组元素的值&#xff0c;将较小的数排在较大的数前面&#xff0c;可实现数组元素的从小到大排序&#xff1b;每次将较大的数排在较小的数前面&#xff0c;可实现数组元素从大到小排序。 /**每次比较数组相邻的两个…

发票查验详情、C票据识别、发票ocr

翔云人工智能开放平台自从上架了发票识别、发票验真两个API产品接到了不少咨询&#xff0c;除了产品本身咨询&#xff0c;同时也记录了一些容易被忽略的开票注意事项&#xff0c;在此分享几个典型的示例给大家&#xff0c;希望能帮到相关业务人员。 翔云发票验真 问题1&#…

文件摆渡:安全、高效的摆渡系统助力提升效率

很多组织和企业都会通过网络隔离的方式来保护内部的数据&#xff0c;网络隔离可以是物理隔离&#xff0c;也可以是逻辑隔离&#xff0c;如使用防火墙、VPN、DMZ等技术手段来实现&#xff0c;隔离之后还会去寻找文件摆渡方式&#xff0c;来保障日常的业务和经营需求。 进行网络隔…