stream().map()方法详解

使用Stream流时发现其中的map方法使用不好容易理解,网上很多都说得很含糊不清,这里以一个小案例探讨一下Stream中map的使用。

案例涉及知识点:

1、Stream中of方法传入可变参数
2、Stream中map元素类型转化方法
3、Function匿名接口,自定义类匿名对象的使用
4、Lambda表达式

为了便于理解,首先借鉴其他博客中的说法,

stream()优点

无存储。stream不是一种数据结构,它只是某种数据源的一个视图,数据源可以是一个数组,Java容器或I/O channel等。
为函数式编程而生。对stream的任何修改都不会修改背后的数据源,比如对stream执行过滤操作并不会删除被过滤的元素,而是会产生一个不包含被过滤元素的新stream。
惰式执行。stream上的操作并不会立即执行,只有等到用户真正需要结果的时候才会执行。
可消费性。stream只能被“消费”一次,一旦遍历过就会失效,就像容器的迭代器那样,想要再次遍历必须重新生成。
stream().map()方法的使用示例:

我的理解侧重于迭代器,结合lambda表达式实现自己的功能。

首先看代码:

package com.myspringtest.streammaptest;

import lombok.Data;

import java.util.ArrayList;

@Data//省去了get、set方法,需要在pom.xml文件中导入lombok依赖
public class UserTest {

    private String username;
    private String password;
    private Integer age;
    public UserTest(){

    }

    public UserTest(String username, String password, Integer age) {
        this.username = username;
        this.password = password;
        this.age = age;
    }


    //public static void main(final String... args)
    public static void main(String[] args)
    {
        ArrayList<UserTest> list = new ArrayList<>();

        list.add(new UserTest("liubei","111",40));
        list.add(new UserTest("zhangfei","222",30));
        list.add(new UserTest("guanyu","333",35));

        System.out.println("list: "+list.toString());

        System.out.println("\ntest1:");
        list.stream().map(n->n)
                .forEach(n-> System.out.println(n));

        System.out.println("\ntest2--age:");
        list.stream().map(n->n.getAge())
                .forEach(n-> System.out.println(n));

        System.out.println("\ntest3--age:");
        list.stream().map(n->n.getAge())
                .map(n->n).forEach(n-> System.out.println(n));

        System.out.println("\ntest2--username:");
        list.stream().map(n->n.getUsername())
                .forEach(n-> System.out.println(n));

        System.out.println("\ntest3--username:");
        //list.stream().map(n->n.getUsername()).map(n->n).forEach(n-> System.out.println(n));
        list.stream().map(n->n.getUsername())
                .forEach(n-> System.out.println(n));
    }
}

 

代码解释:

为了减少篇幅,我这里新建了一个spring 工程,只包括一个Java文件,文件中包括了自定义类UserTest、main函数。
1、UserTest包括三个成员变量和一个无参构造函数、一个有参构造函数;
2、导入@Data注释增强了代码简洁性,省去了get、set方法,使用这一注释需要在pom.xml文件中导入lombok依赖。

运行结果

list: [UserTest(username=liubei, password=111, age=40),
UserTest(username=zhangfei, password=222, age=30),
UserTest(username=guanyu, password=333, age=35)]

test1: UserTest(username=liubei, password=111, age=40)
UserTest(username=zhangfei, password=222, age=30)
UserTest(username=guanyu, password=333, age=35)

test2–age: 40 30 35

test3–age: 40 30 35

test2–username: liubei zhangfei guanyu

test3–username: liubei zhangfei guanyu

Process finished with exit code 0

这样,就可以看明白了,map方法类似一个迭代器,对调用这个Stream.map(**)的对象进行lambda表达式操作。

更多Stream方法点击1、Java8 Stream特性
2、stream.map重写Function函数示例
查看

  • 9
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: Streammap方法类似于一个迭代器,它对调用这个Stream.map()的对象进行lambda表达式操作。\[1\] 但是需要注意的是,map方法只能针对一维数组进行操作,无法处理多维数组或嵌套的流。如果需要将多维数组或嵌套的流展开到父流中进行处理,可以使用flatMap方法。flatMap方法可以将子流中的元素平面展开到父流中进行处理。\[2\] 举个例子,如果有一个字符串列表words,我们可以使用flatMap方法将每个单词拆分成字符,并将所有字符展开到一个新的流中进行处理。例如,words.stream().flatMap(w -> Arrays.stream(w.split("")))会将每个单词拆分成字符,并将所有字符展开到一个新的流中。\[2\] 这样就可以对每个字符进行操作了。而如果使用map方法,无法实现这样的功能,因为map方法要求原始流中的元素和新流中的元素个数相同,或者理解为一一对应。\[3\] 所以,如果需要处理多维数组或嵌套的流,应该使用flatMap方法。 #### 引用[.reference_title] - *1* [stream().map()方法详解](https://blog.csdn.net/m0_67393686/article/details/124152444)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [streammap的用法](https://blog.csdn.net/lyh1023812/article/details/121538987)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [这么简单,还不会使用java8 stream流的map()方法吗?](https://blog.csdn.net/Candyz7/article/details/128158333)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值