Stream流

Stream流

Stream流的作用

结合lambda表达式,简化集合、数组的操作

Stream流的使用步骤

先得到一条Stream流,并把数据放上去
使用中间方法处理数据
中间方法 过滤、转换 方法调用完毕后,还可以调用其他方法
使用终结方法处理数据
终结方法 统计、打印 最后一步,调用完毕后,不能调用其他方法

Stream流获取方式

获取方式

方法名

说明

单列集合

defailt Stream< E > stream()

Collection中的默认方法

双列集合

无法直接使用stream流

数组

public static < T > Stream< T > stream(T[] array)

Arrays工具类中的静态方法

一堆零散数据

public static < T > Stream< T > of(T...values)

Stream接口中的静态方法

下面结合代码:

  • 单列集合获取stream流

ArrayList<String> list = new ArrayList<>();
Collections.addAll(list,"a","b","c","d","e");
list.stream().forEach(s -> System.out.println(s));  //结合lambda表达式
  • 双列集合获取stream流

HashMap<String,Integer> h = new HashMap();
h.put("aaa",111);
h.put("bbb",222);
h.put("ccc",333);
h.put("ddd",444);
//第一种
h.keySet().stream().forEach(s -> System.out.println(s));
//第二种
h.entrySet().stream().forEach(s -> System.out.println(s));
  • 数组获取stream流

String[] arr = {"a","b","c","d","e"};
Arrays.stream(arr).forEach(s -> System.out.println(s));
  • 一堆零散数据获取stream流

Stream.of(1,2,3,4,5,6).forEach(s -> System.out.println(s));  //要求数据类型相同

Stream接口中的静态方法的of方法的形参是可变参数,其底层就是数组,可以传递一堆零散的数据,也可以传递数组,但是数组必须是引用数据类型,如果传递基本数据类型,是会把整个数组当作一个元素,放到Stream当中,打印出来的是地址

常见方法

中间方法

名称

说明

Stream filter(Predicate<? super T> predicate)

过滤

Stream limit(long maxSize)

获取前几个元素

Stream skip(long n)

跳过前几个元素

Stream distinct()

元素去重,依赖(hashCode和equals方法)

static Stream concat(Stream a,Stream b)

合并a和b两个流为一个流

Stream map(Function<T,R> mapper)

转换流中的数据类型

注意:

  • 中间方法,返回新的Stream流,原来的Stream流只能使用一次,建议使用链式编程

  • 修改Stream流中的数据,不会影响原来集合或者数组中的数据

  • 自定义对象去重时需要自己手动重写hashCode和equals方法

ArrayList<String> list = new ArrayList<>();
Collections.addAll(list,"孙尚香","孙策","张三","干将莫邪","张良","张飞","李四","李四","李四");

ArrayList<String> list1 = new ArrayList<>();
Collections.addAll(list,"王五","赵六");

list.stream().filter(s -> s.startsWith("张")).forEach(s -> System.out.print(s + "\t"));

System.out.println();
System.out.println("-------------------------------");
list.stream().filter(s -> s.startsWith("孙") && s.length() == 3).forEach(s -> System.out.print(s + "\t"));

System.out.println();
System.out.println("-------------------------------");
list.stream().limit(3).forEach(s -> System.out.print(s + "\t"));

System.out.println();
System.out.println("-------------------------------");
list.stream().skip(4).forEach(s -> System.out.print(s + "\t"));

System.out.println();
System.out.println("-------------------------------");
list.stream().distinct().forEach(s -> System.out.print(s + "\t"));

System.out.println();
System.out.println("-------------------------------");
Stream.concat(list.stream(),list1.stream()).forEach(s -> System.out.print(s + "\t"));

ArrayList<String> list2 = new ArrayList<>();
Collections.addAll(list2,"孙尚香-15","孙策-16","张三-15","干将莫邪-20","张良-18","张飞-19","李四-18");

System.out.println();
System.out.println("-------------------------------");
//第一个类型:流中原本的数据类型
//第二个类型:要转换成之后的类型

//apply的形参s:依次表示流里面的每一个数据
//返回值:表示转换之后的数据
list2.stream().map(new Function<String, Integer>() {
    @Override
    public Integer apply(String s) {
        String[] arr = s.split("-");
        String s1 = arr[1];
        int a = Integer.parseInt(s1);
        return a;
    }
}).forEach(s -> System.out.print(s + "\t"));

运行结果

终结方法

名称

说明

void forEach(Consumer action)

遍历

long count()

统计

toArray()

收集流中的数据,放到数组中

collect(Collector collector)

收集流中的数据,放到集合中

首先是前三个方法
ArrayList<String> list = new ArrayList<>();
Collections.addAll(list,"孙尚香","孙策","张三","干将莫邪","张良","张飞","李四","李四");

list.stream().forEach(s -> System.out.print(s + "\t"));

System.out.println();
System.out.println("----------------------");
System.out.println(list.stream().count());

//toArray方法的参数的作用:负责创建一个指定类型的数组,若无参数默认为Object类型
//toArray方法的底层:会依次得到流里面的每一个数据,并把数据放到数组中
//toArray方法的返回值:是一个装着流里面所有数据的数组
System.out.println("----------------------");
Object[] arr1 = list.stream().toArray();
System.out.println(Arrays.toString(arr1));

System.out.println("----------------------");
String[] arr2 = list.stream().toArray(new IntFunction<String[]>() {
    @Override
    public String[] apply(int value) {
        return new String[value];
    }
});
System.out.println(Arrays.toString(arr2));

运行结果

收集方法
  • 收集到List和Set中

ArrayList<String> list = new ArrayList<>();
Collections.addAll(list, "孙尚香-女-18", "孙策-男-19", "张三-男-20", "干将莫邪-男-21", "张良-男-22", "张飞-男-25", "李四-男-23","李四-男-23");

//收集List集合中
//把男性收集起来
List<String> newList = list.stream().filter(s -> "男".equals(s.split("-")[1])).collect(Collectors.toList());
System.out.println(newList);

System.out.println("------------------------------------------------------");

//收集Set集合中
Set<String> newSet = list.stream().filter(s -> "男".equals(s.split("-")[1])).collect(Collectors.toSet());
System.out.println(newSet);

运行结果:Set集合可以去重

  • 收集到Map集合中

//收集Map集合中
Map<String, Integer> map = list.stream().filter(s -> "男".equals(s.split("-")[1]))
    /**
    * toMap : 参数一表示键的生成规则
    *         参数一表示键的生成规则
    * 参数一:
    *       Function泛型一:表示流中每一个数据类型
    *               泛型一:表示Map集合中键的数据类型
    *         方法apply形参:依次表示流里面的每一个数据
    *                  方法体:生成键的代码
    *                  返回值:已经生成的键
    *  参数二:
    *        Function泛型一:表示流中每一个数据类型
    *                泛型一:表示Map集合中值的数据类型
    *          方法apply形参:依次表示流里面的每一个数据
    *                   方法体:生成键的代码
    *                   返回值:已经生成的键
    */
    .collect(Collectors.toMap(
        new Function<String, String>() {
            @Override
            public String apply(String s) {
                return s.split("-")[0];
            }
        },
        new Function<String, Integer>() {
            @Override
            public Integer apply(String s) {
                return Integer.parseInt(s.split("-")[2]);
            }
        }));
System.out.println(map);

Map<String, Integer> map1 = list.stream()
    .filter(s -> "男".equals(s.split("-")[1]))
    .collect(Collectors.toMap(
        s -> s.split("-")[0]
        ,
        s -> Integer.parseInt(s.split("-")[2])
    ));
System.out.println(map1);

运行结果

注意:键不能重复,否则会报错

案例

数据过滤并收集

定义一个集合,并添加一些整数1,2,3,4,5,6,7,8,9,10
过滤奇数,只留下偶数
并将结果保存起来
ArrayList<Integer> list = new ArrayList<>();
Collections.addAll(list,1,2,3,4,5,6,7,8,9,10);
List<Integer> list1 = list.stream().filter(s -> s % 2 == 0).collect(Collectors.toList());
System.out.println(list1);

List<Integer> list2 = list.stream().filter(s -> s % 2 != 0).collect(Collectors.toList());
System.out.println(list2);

运行结果

字符串过滤并收集

创建一个ArrayList集合,并添加以下字符串,字符串中前面是姓名,后面是年龄
"zhangsan,23"
"lisi,24"
"wangwu,25"
保留年龄大于等于24岁的人,并将结果收集到Map集合中,姓名为键,年龄为值
ArrayList<String> list = new ArrayList<>();
Collections.addAll(list,"zhangsan,23","lisi,24","wangwu,25");
Map<String, Integer> map = list.stream().filter(s -> Integer.parseInt(s.split(",")[1]) >= 24)
    .collect(Collectors.toMap(
        s -> s.split(",")[0]
        ,
        s -> Integer.parseInt(s.split(",")[1])
    ));
System.out.println(map);

运行结果

自定义对象过滤并收集

现有两个ArrayList集合
第一个集合中:存储6名男学生的名字和年龄
第二个集合中:存储6名女学生的名字和年龄
要求完成如下操作:
男学生只要名字为三个字的前两人
女学生只要姓孙的,并且不要第一个
把过滤后的男学生和女学生合并到一起
将上一步的演员信息封装成Actor对象
将所有的演员对象都保存到List集合中
学生类Student 属性有:姓名、年龄
1ArrayList<String> list1 = new ArrayList<>();
Collections.addAll(list1,"刘备,22","诸葛亮,21","吕布,22","猪八戒,20","李白,20","李元芳,18");
ArrayList<String> list2 = new ArrayList<>();
Collections.addAll(list2,"孙尚香,21","孙膑,22","甄姬,20","貂蝉,20","王昭君,21","妲己,23");

System.out.println("---------------------1.----------------------");

list1.stream()
    .filter(s -> s.split(",")[0].length() == 3)
    .limit(2)
    .forEach(s -> System.out.print(s + "\t"));

System.out.println();
System.out.println("---------------------2.----------------------");

list2.stream()
    .filter(s -> s.split(",")[0].startsWith("孙"))
    .skip(1)
    .forEach(s -> System.out.print(s + "\t"));

运行结果

 System.out.println("---------------------3. 4. 5.----------------------");

List<Student> list = Stream.concat(stream1, stream2).
    map(s -> new Student(s.split(",")[0], Integer.parseInt(s.split(",")[1])))
    .collect(Collectors.toList());
System.out.println(list);

运行结果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
vuex辅助函数是一组为了简化在Vue组件中访问和使用store中的state、getter、mutation和action的工具函数。使用辅助函数可以减少代码量并提高代码的可读性。其中常用的辅助函数包括mapState、mapGetters、mapMutations和mapActions。 mapState函数可以帮助我们将store中的state映射到组件的计算属性中,使得我们可以直接在组件中访问state的值而不需要通过this.$store.state.xx来获取。这样可以简化代码,并且使得组件与store的关系更加清晰。 mapGetters函数可以帮助我们将store中的getter映射到组件的计算属性中。getter可以理解为store中的派生状态,通过对state的计算而得到的值。使用mapGetters可以让我们在组件中直接访问这些派生状态的值,而不需要通过this.$store.getters.xx来获取。 mapMutations函数可以帮助我们将store中的mutation映射到组件的方法中。mutation是修改store中state的唯一途径,通过提交mutation可以保证所有对state的修改都是同步的。使用mapMutations可以让我们在组件中直接调用mutation的方法,而不需要通过this.$store.commit('mutation名')来提交mutation。 mapActions函数可以帮助我们将store中的action映射到组件的方法中。action可以包含任意异步操作,并通过提交mutation来修改state。使用mapActions可以让我们在组件中直接调用action的方法,而不需要通过this.$store.dispatch('action名')来派发action。 总的来说,vuex辅助函数的作用是简化在Vue组件中访问和使用store中的状态、派生状态、修改状态和派发异步操作的代码,提高代码的可读性和可维护性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Vue全家桶学习—Vuex的4个辅助函数](https://blog.csdn.net/ZHANGYANG_1109/article/details/122050052)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [解决mpvue + vuex 开发微信小程序vuex辅助函数mapState、mapGetters不可用问题](https://download.csdn.net/download/weixin_38680671/13607816)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [vuex及其辅助函数](https://blog.csdn.net/qq_45718618/article/details/130002839)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值