Lucent's Blog

当时明月在,曾照彩云归。



代码在写我

Bug在De我

螃蟹在剥我的壳

漫天的我落在雪花上

而你在想我...

6ams5piO5pyI

Stream管道流的map操作

Stream管道流map的基础用法

将集合中的每一个字符串,全部转换成大写:

List<String> alpha = Arrays.asList("Monkey", "Lion", "Giraffe", "Lemur");
List<String> collect = alpha.stream().map(String::toUpperCase).collect(Collectors.toList());
System.out.println(collect);

结果:

[MONKEY, LION, GIRAFFE, LEMUR]

map()函数不仅可以处理数据,还可以转换数据的类型:

List<Integer> lengths = alpha.stream()
        .map(String::length)
        .collect(Collectors.toList());
System.out.println(lengths); 

结果:

[6, 4, 7, 5]
Stream.of("Monkey", "Lion", "Giraffe", "Lemur")
        .mapToInt(String::length)
        .forEach(System.out::println);

结果:

6
4
7
5

处理对象数据

将每一个Employee的年龄增加一岁并且将性别中的“M”换成“male”,F换成Female:

Employee e1 = new Employee(1,23,"M","Rick","Beethovan");
            Employee e2 = new Employee(2,13,"F","Martina","Hengis");
            Employee e3 = new Employee(3,43,"M","Ricky","Martin");
            Employee e4 = new Employee(4,26,"M","Jon","Lowman");
            Employee e5 = new Employee(5,19,"F","Cristine","Maria");
            Employee e6 = new Employee(6,15,"M","David","Feezor");
            Employee e7 = new Employee(7,68,"F","Melissa","Roy");
            Employee e8 = new Employee(8,79,"M","Alex","Gussin");
            Employee e9 = new Employee(9,15,"F","Neetu","Singh");
            Employee e10 = new Employee(10,45,"M","Naveen","Jain");

            List<Employee> employees = Arrays.asList(e1, e2, e3, e4, e5, e6, e7, e8, e9, e10);
//使用map
List<Employee> maped = employees.stream()
                .map(e -> {
                    e.setAge(e.getAge() + 1);
                    e.setGender(e.getGender().equals("M")?"male":"female");
                    return e;
                }).collect(Collectors.toList());
            System.out.println(maped);
//使用peek
maped = employees.stream()
                .peek(e -> {
                    e.setAge(e.getAge() + 2);
                    e.setGender(e.getGender().equals("M")?"male":"female");
                }).collect(Collectors.toList());
        System.out.println(maped);

peek函数是一种特殊的map函数,当函数没有返回值或者参数就是返回值的时候可以使用peek函数。

flatMap

map可以对管道流中的数据进行转换操作,但是如果管道中还有管道该如何处理?即:如何处理二维数组及二维集合类。
一个简单的需求:将“hello”,“world”两个字符串组成的集合,元素的每一个字母打印出来:

 List<String> words = Arrays.asList("hello", "word");
        words.stream()
                .map(w -> Arrays.stream(w.split("")))    
                .forEach(System.out::println);

结果:

[email protected]
[email protected]

用map方法是做不到的,这个需求用map方法无法实现。map只能针对一维数组进行操作,数组里面还有数组,管道里面还有管道,它是处理不了每一个元素的。
而flatMap可以做到:

words.stream()
        .flatMap(w -> Arrays.stream(w.split(""))) 
        .forEach(System.out::println);

结果:

h
e
l
l
o
w
o
r
d
最近的文章

Stream的状态与并行操作

有状态与无状态在编程中,经常会接触到“有状态”,“无状态”,绝大部分的人都比较蒙。而且在不同的场景下,“状态”这个词的含义似乎有所不同。状态通常代表公用数据,有状态就是有“公用数据”因为有公用的数据,状态通常需要额外的存储。状态通常被多人、多用户、多线程、多次操作,这就涉及到状态的管理及变更操作。…

继续阅读
更早的文章

Stream的filter与谓语逻辑

什么是谓语逻辑如下代码中WHERE和AND限定了主语employee是什么,那么WHERE和AND语句所代表的逻辑就是谓语逻辑。…

继续阅读