java8 foreach用法list转map、map转list

简介: java8 foreach用法list转map、map转list

一、list转为map

@Test
    public void test010(){
        Map<String,String> map = Maps.newHashMap();
        List<BackupQueueManage> backups = Lists.newArrayList();
        BackupQueueManage queue = new BackupQueueManage();
        queue.setQueueName("oracle-090909");
        queue.setDbType("DB2");
        queue.setLinkScriptId("1");
        queue.setScheduleType("0");
        backups.add(queue);
        backups.forEach(e ->{
            map.put("queueName",e.getQueueName());
            map.put("DbType",e.getDbType());
            map.put("LinkScriptId",e.getLinkScriptId());
            map.put("ScheduleType",e.getScheduleType());
        });
        System.out.println(map);
    }
运行结果
{ScheduleType=0, LinkScriptId=1, queueName=oracle-090909, DbType=DB2}

二、map转为list

@Test
    public void test010(){
        Map<String,String> map = Maps.newHashMap();
        map.put("queueName","oracle-090909");
        map.put("DbType","DB2");
        map.put("LinkScriptId","1");
        map.put("ScheduleType","0");
        List<Map<String,String>> results = Lists.newArrayList();
        map.forEach((k,v) -> {
            Map<String,String> tempMap = Maps.newHashMap();
            tempMap.put(k,v);
            results.add(tempMap);
        });
        System.out.println(results);
    }
运行结果
[{ScheduleType=0}, {LinkScriptId=1}, {queueName=oracle-090909}, {DbType=DB2}]


相关文章
|
2月前
|
算法
你对Collection中Set、List、Map理解?
你对Collection中Set、List、Map理解?
79 18
你对Collection中Set、List、Map理解?
|
2月前
|
存储 缓存 安全
只会“有序无序”?面试官嫌弃的List、Set、Map回答!
小米,一位热衷于技术分享的程序员,通过与朋友小林的对话,详细解析了Java面试中常见的List、Set、Map三者之间的区别,不仅涵盖了它们的基本特性,还深入探讨了各自的实现原理及应用场景,帮助面试者更好地准备相关问题。
73 20
|
3月前
|
存储
`map()`方法在什么场景下会比 `forEach()`方法更高效?
综上所述,当需要对数组元素进行复杂的转换并生成新数组、进行链式调用和函数式编程、处理元素之间存在明确映射关系的情况以及与其他数组方法结合使用时,`map()`方法比`forEach()`方法更高效,能够使代码更加简洁、清晰和易于维护。
83 32
|
3月前
|
存储 JavaScript 前端开发
如何选择使用`map()`方法和`forEach()`方法?
选择使用`map()`方法还是`forEach()`方法主要取决于操作的目的、是否需要返回值、代码的可读性和维护性等因素。在实际开发中,需要根据具体的业务需求和场景来灵活选择合适的方法,以实现更高效、更易读和更易维护的代码。
45 3
|
3月前
|
存储 Java API
Java交换map的key和value值
通过本文介绍的几种方法,可以在Java中实现Map键值对的交换。每种方法都有其优缺点,具体选择哪种方法应根据实际需求和场景决定。对于简单的键值对交换,可以使用简单遍历法或Java 8的Stream API;对于需要处理值不唯一的情况,可以使用集合存储或Guava的Multimap。希望本文对您理解和实现Java中的Map键值对交换有所帮助。
68 1
|
4月前
|
安全 Java 程序员
深入Java集合框架:解密List的Fail-Fast与Fail-Safe机制
本文介绍了 Java 中 List 的遍历和删除操作,重点讨论了快速失败(fail-fast)和安全失败(fail-safe)机制。通过普通 for 循环、迭代器和 foreach 循环的对比,详细解释了各种方法的优缺点及适用场景,特别是在多线程环境下的表现。最后推荐了适合高并发场景的 fail-safe 容器,如 CopyOnWriteArrayList 和 ConcurrentHashMap。
99 5
|
4月前
|
Java 程序员 编译器
Java|如何正确地在遍历 List 时删除元素
从源码分析如何正确地在遍历 List 时删除元素。为什么有的写法会导致异常,而另一些不会。
91 3
|
4月前
|
Java 程序员
Java|List.subList 踩坑小记
不应该仅凭印象和猜测,就开始使用一个方法,至少花一分钟认真读完它的官方注释文档。
49 1
|
4月前
|
存储 缓存 安全
在Java的Map家族中,HashMap和TreeMap各具特色
【10月更文挑战第19天】在Java的Map家族中,HashMap和TreeMap各具特色。HashMap基于哈希表实现,提供O(1)时间复杂度的高效操作,适合性能要求高的场景;TreeMap基于红黑树,提供O(log n)时间复杂度的有序操作,适合需要排序和范围查询的场景。两者在不同需求下各有优势,选择时需根据具体应用场景权衡。
52 2
|
8月前
|
安全 Java
java线程之List集合并发安全问题及解决方案
java线程之List集合并发安全问题及解决方案
1120 1