• java集合 stream 相关用法(1)


    java8新增一种流式数据,让操作集合数据更简单方便。

    定义基本对象:

    public class Peo {
    
        private String name;
        
        private String id;
    
        
        
        public Peo() {
            super();
        }
    
        public Peo(String name, String id) {
            super();
            this.name = name;
            this.id = id;
        }
    
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        public String getId() {
            return id;
        }
    
        public void setId(String id) {
            this.id = id;
        }
        
        
    }

    1.toMap的使用

     使用toMap方法将list集合转出对应的map

    import java.util.ArrayList;
    import java.util.List;
    import java.util.Map;
    import java.util.stream.Collectors;
    
    public class Stemap {
    
        public static void main(String[] args) {
            
            List<Peo> list = new ArrayList<>();
            
            list.add(new Peo("a", "1"));
            list.add(new Peo("b", "2"));
            list.add(new Peo("c", "3"));
            list.add(new Peo("d", "4"));
            
            
            Map<String, Peo> map = list.stream().collect(Collectors.toMap(Peo::getId, s -> s));
    //获取单字段集合 List<String> names = list.stream().map(e -> e.getName).collect(Collectors.toList()); map.keySet().forEach(s
    ->{ System.out.println(s); }); } }

    使用

    Collectors.toMap方法将list转成Map,key = Id,value = Peo对象
    注意key值不能有重复,如果有重复就会报错,为了解决这种问题,我们可以使用以下的写法:

    Map<String, Peo> map = list.stream().collect(Collectors.toMap(Peo::getId, s -> s,(s1,s2)->s1));

    多加的一个方法(s1,s2)->s1,是指当遇到key值相同时,value使用已经添加的,忽略后面的对象,如果这么写(s1,s2)->s2,将会把后面的对象替换到map中,如下:

    import java.util.ArrayList;
    import java.util.List;
    import java.util.Map;
    import java.util.stream.Collectors;
    
    public class Stemap {
    
        public static void main(String[] args) {
            
            List<Peo> list = new ArrayList<>();
            
            list.add(new Peo("a", "1"));
        /*    list.add(new Peo("b", "2"));
            list.add(new Peo("c", "3"));
            list.add(new Peo("d", "4"));*/
            list.add(new Peo("e", "1"));
            
            
            Map<String, Peo> map1 = list.stream().collect(Collectors.toMap(Peo::getId, s -> s,(s1,s2)->s1));
            
            System.out.println(map1.get("1").getName());
            
            Map<String, Peo> map2 = list.stream().collect(Collectors.toMap(Peo::getId, s -> s,(s1,s2)->s2));
            
            System.out.println(map2.get("1").getName());
            
            /*map1.values().forEach(s->{
                System.out.println(s);
            });*/
            
        }
    }

    输出如下:

    2.groupBy

    import java.util.ArrayList;
    import java.util.List;
    import java.util.Map;
    import java.util.stream.Collectors;
    
    public class Stemap {
    
        public static void main(String[] args) {
            
            List<Peo> list = new ArrayList<>();
            
            list.add(new Peo("a", "1"));
            list.add(new Peo("b", "2"));
            list.add(new Peo("c", "3"));
            list.add(new Peo("d", "4"));
            list.add(new Peo("e", "1"));
            
            
            Map<String, List<Peo>> map1 = list.stream().collect(Collectors.groupingBy(Peo::getId));
            
            System.out.println("map 数量:"+map1.size());
            
            System.out.println("key = 1 数量:"+map1.get("1").size());
            map1.get("1").forEach(p ->{
                System.out.println(p.getName());
            });
            
            
            /*map1.values().forEach(s->{
                System.out.println(s);
            });*/
            
        }
    }

    输出如下:

    我们可以通过groupBy方法对list数据分组,指定分组的key。

    3.filter

    import java.util.ArrayList;
    import java.util.List;
    import java.util.stream.Collectors;
    
    public class Stemap {
    
        public static void main(String[] args) {
            
            List<Peo> list = new ArrayList<>();
            
            list.add(new Peo("a", "1"));
            list.add(new Peo("b", "2"));
            list.add(new Peo("c", "3"));
            list.add(new Peo("d", "4"));
            list.add(new Peo("e", "1"));
            
            
            list = list.stream().filter(peo -> "1".equals(peo.getId())).collect(Collectors.toList());;
            
            list.forEach(p ->{
                System.out.println(p.getName());
            });
            
            
            /*map1.values().forEach(s->{
                System.out.println(s);
            });*/
            
        }
    }

    输出:

    可用通过filter过滤出满足一定条件的数据。

    后续还有关于distinct、limit、skip、allMatch等等方法,后面继续补充

  • 相关阅读:
    梯度下降-Momentum
    6-10-HIRP OPEN 2016
    机器学习数目推荐
    《统计、计算和未来-李航》读后感
    MongoDB $关键字 $修改器
    MongoDB数据类型
    MongoDB操作(增删改查)
    MongoDB安装及开启(Windows)
    第七周:论文泛读(二)
    第六周:论文泛读(一)
  • 原文地址:https://www.cnblogs.com/wangzun/p/10529550.html
Copyright © 2020-2023  润新知