java8中常用list、map转换(Stream、function)

由于经常用到List、Map之间的转换,java8中的新特性function又能很显著的减少代码量,用来取代之前的foreach操作最合适不过了。

以下为代码:

// 将实体类的list,转换为map
List userList = new LinkedList<>();
Map userMap = userList.
                stream().
                collect(Collectors.toMap(
                item -> item.getId(),// 操作map的key
                item-> item,// 操作map的value
                (v1,v2)->v1
        ));
// 更简单的方式
Map userMap1 = userList.
                stream().
                collect(Collectors.toMap(
                item -> item.getId(),// 操作map的key
                Function.identity()));// 适用于map的value是item的本身

// List  -> List
List sourceList = new ArrayList<>();
List targetList = sourceList.stream().
                map(String::valueOf).collect(Collectors.toList());

// List  -> List
List sourceList = new ArrayList<>();
List targetList = sourceList.stream().
                map((str -> Integer.parseInt(str))).collect(Collectors.toList());

// List 与 String转换
List sourceList = new ArrayList<>();
String targetStr = String.join(",",sourceList );// 第一个参数为形成字符串后的连接符
// String 与 List转换
List targetList = Arrays.asList(targetStr.split(","));// 参数为字符串的连接符
// 注意:以上代码为伪代码,实际操作时应注意非空验证

// 对比串行与并行的效率(stream/parallelStream)
List intList = new ArrayList<>();
        for(int i=0;i<100000;i++) {
            intList.add(i);
        }
        
        long t1 = System.currentTimeMillis();
        List collect = intList.stream().map(integer1 -> integer1 + "key").collect(Collectors.toList());
        long t2 = System.currentTimeMillis();
        List collect1 = intList.parallelStream().map(integer1 -> integer1 + "key").collect(Collectors.toList());
        long t3 = System.currentTimeMillis();
        System.out.println("---串行:"+(t2-t1));//---串行:38
        System.out.println("---并行:"+(t3-t2));//---并行:17

于时间:2019/7/26 23:57:30

 

你可能感兴趣的:(项目记录)