• 处理 List、Set、Map 的相互转换问题


    📕我是廖志伟,一名Java开发工程师、Java领域优质创作者、CSDN博客专家、51CTO专家博主、阿里云专家博主、清华大学出版社签约作者、产品软文创造者、技术文章评审老师、问卷调查设计师、个人社区创始人、开源项目贡献者。🌎跑过十五公里、徒步爬过衡山、🔥有过三个月减肥20斤的经历、是个喜欢躺平的狠人。

    📘拥有多年一线研发和团队管理经验,研究过主流框架的底层源码(Spring、SpringBoot、Spring MVC、SpringCould、Mybatis、Dubbo、Zookeeper),消息中间件底层架构原理(RabbitMQ、RockerMQ、Kafka)、Redis缓存、MySQL关系型数据库、 ElasticSearch全文搜索、MongoDB非关系型数据库、Apache ShardingSphere分库分表读写分离、设计模式、领域驱动DDD、Kubernetes容器编排等。🎥有从0到1的高并发项目经验,利用弹性伸缩、负载均衡、报警任务、自启动脚本,最高压测过200台机器,有着丰富的项目调优经验。

    以梦为马,不负韶华

    希望各位读者大大多多支持用心写文章的博主,现在时代变了,信息爆炸,酒香也怕巷子深,博主真的需要大家的帮助才能在这片海洋中继续发光发热,所以,赶紧动动你的小手,点波关注❤️,点波赞👍,点波收藏⭐,甚至点波评论✍️,都是对博主最好的支持和鼓励!

    📥博主的人生感悟和目标

    探寻内心世界,博主分享人生感悟与未来目标

    • 🍋程序开发这条路不能停,停下来容易被淘汰掉,吃不了自律的苦,就要受平庸的罪,持续的能力才能带来持续的自信。我本是是一个很普通程序员,放在人堆里,除了与生俱来的盛世美颜,就剩180的大高个了,就是我这样的一个人,默默写博文也有好多年了。
    • 📺有句老话说的好,牛逼之前都是傻逼式的坚持,希望自己可以通过大量的作品、时间的积累、个人魅力、运气、时机,可以打造属于自己的技术影响力。
    • 💥内心起伏不定,我时而激动,时而沉思。我希望自己能成为一个综合性人才,具备技术、业务和管理方面的精湛技能。我想成为产品架构路线的总设计师,团队的指挥者,技术团队的中流砥柱,企业战略和资本规划的实战专家。
    • 🎉这个目标的实现需要不懈的努力和持续的成长,但我必须努力追求。因为我知道,只有成为这样的人才,我才能在职业生涯中不断前进并为企业的发展带来真正的价值。在这个不断变化的时代,我必须随时准备好迎接挑战,不断学习和探索新的领域,才能不断地向前推进。我坚信,只要我不断努力,我一定会达到自己的目标。

    CSDN

    📙经过多年在CSDN创作上千篇文章的经验积累,我已经拥有了不错的写作技巧。同时,我还与清华大学出版社签下了四本书籍的合约,并将陆续在明年出版。这些书籍包括了基础篇、进阶篇、架构篇的📌《Java项目实战—深入理解大型互联网企业通用技术》📌,以及📚《解密程序员的思维密码–沟通、演讲、思考的实践》📚。具体出版计划会根据实际情况进行调整,希望各位读者朋友能够多多支持!

    🌾阅读前,快速浏览目录和章节概览可帮助了解文章结构、内容和作者的重点。了解自己希望从中获得什么样的知识或经验是非常重要的。建议在阅读时做笔记、思考问题、自我提问,以加深理解和吸收知识。阅读结束后,反思和总结所学内容,并尝试应用到现实中,有助于深化理解和应用知识。与朋友或同事分享所读内容,讨论细节并获得反馈,也有助于加深对知识的理解和吸收。

    🔔如果您需要转载或者搬运这篇文章的话,非常欢迎您私信我哦~

    💡在这个美好的时刻,本人不再啰嗦废话,现在毫不拖延地进入文章所要讨论的主题。接下来,我将为大家呈现正文内容。

    CSDN

    🌟 处理 List、Set、Map 的相互转换问题

    在 Java 开发中,我们经常遇到需要将 List、Set、Map 之间进行相互转换的情况。这些数据结构常用于存储集合数据,但它们之间的数据结构不同,因此需要进行相关的转换操作。

    在本篇文章中,我们将探讨如何处理 List、Set、Map 的相互转换问题,并且提供一些实用的示例代码。

    🍊 List 与 Set 的转换

    🎉 List 转 Set

    List 转 Set 可以通过使用 HashSetTreeSet 来实现。HashSet 是无序的,而 TreeSet 是有序的。

    List<String> list = new ArrayList<>();
    list.add("Alice");
    list.add("Bob");
    list.add("Charlie");
    
    Set<String> set1 = new HashSet<>(list); // 使用 HashSet 转换
    Set<String> set2 = new TreeSet<>(list); // 使用 TreeSet 转换
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    🎉 Set 转 List

    Set 转 List 可以使用 ArrayListLinkedList 来实现。

    Set<String> set = new HashSet<>();
    set.add("Alice");
    set.add("Bob");
    set.add("Charlie");
    
    List<String> list1 = new ArrayList<>(set); // 使用 ArrayList 转换
    List<String> list2 = new LinkedList<>(set); // 使用 LinkedList 转换
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    🍊 List 与 Map 的转换

    🎉 List 转 Map

    将 List 转换成 Map 可以通过遍历 List 并使用 put 方法将其转换成 Map。

    List<Person> list = new ArrayList<>(); // 假设 Person 类有 id 和 name 属性
    list.add(new Person(1, "Alice"));
    list.add(new Person(2, "Bob"));
    list.add(new Person(3, "Charlie"));
    
    Map<Integer, String> map = new HashMap<>();
    for (Person person : list) {
        map.put(person.getId(), person.getName());
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    🎉 Map 转 List

    将 Map 转换成 List 可以通过遍历 Map 并使用 entrySet 方法将其转换成 List。

    Map<Integer, String> map = new HashMap<>();
    map.put(1, "Alice");
    map.put(2, "Bob");
    map.put(3, "Charlie");
    
    List<Person> list = new ArrayList<>();
    for (Map.Entry<Integer, String> entry : map.entrySet()) {
        list.add(new Person(entry.getKey(), entry.getValue()));
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    🍊 Set 与 Map 的转换

    🎉 Set 转 Map

    将 Set 转换成 Map 可以通过遍历 Set 并使用 put 方法将其转换成 Map。

    Set<Person> set = new HashSet<>(); // 假设 Person 类有 id 和 name 属性
    set.add(new Person(1, "Alice"));
    set.add(new Person(2, "Bob"));
    set.add(new Person(3, "Charlie"));
    
    Map<Integer, String> map = new HashMap<>();
    for (Person person : set) {
        map.put(person.getId(), person.getName());
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    🎉 Map 转 Set

    将 Map 转换成 Set 可以通过遍历 Map 并使用 HashSetTreeSet 将其转换成 Set。

    Map<Integer, String> map = new HashMap<>();
    map.put(1, "Alice");
    map.put(2, "Bob");
    map.put(3, "Charlie");
    
    Set<Person> set1 = new HashSet<>();
    for (Map.Entry<Integer, String> entry : map.entrySet()) {
        set1.add(new Person(entry.getKey(), entry.getValue()));
    }
    
    Set<Person> set2 = new TreeSet<>();
    for (Map.Entry<Integer, String> entry : map.entrySet()) {
        set2.add(new Person(entry.getKey(), entry.getValue()));
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    🍊 注意事项

    • 在转换 List 和 Set 的过程中需要注意去重。
    • 在转换 Map 和 Set 的过程中需要注意键的唯一性。

    🍊 总结

    通过本文的讲解,我们可以学习到如何处理 List、Set、Map 的相互转换问题,并且掌握了一些实用的示例代码。

    在实际开发中,我们需要根据具体业务场景来选择适当的数据结构,灵活使用 Java 中的集合类进行数据操作。

  • 相关阅读:
    赐你一本_.武林秘籍,Lodash常用的方法帮助你快速开发。
    计算机二级--java篇
    19、pixelNeRF
    【rust】| 06——语言特性 | 所有权
    阿里巴巴云生态 9 大开源项目重磅发布
    Linux系统Word转换PDF,文档字体乱码不显示问题解决。
    CSS复合选择器(二)
    集成电路模拟版图入门-转行模拟版图基础学习笔记(二)
    SSM框架Demo: 简朴博客系统
    Nginx篇---第三篇
  • 原文地址:https://blog.csdn.net/java_wxid/article/details/132940293