Java 8 Stream截取List

一、需求说明

现有接口需对已注册用户批量注册至极光,极光提供接口仅支持单词500,故使用Stream截取数据库查询结果。

 

二、代码实现

        // 查询所有需注册至极光的用户基础信息
        List<JiGuangInfo> jiGuangInfos = getJiGuangInfoList();
        // 总注册数
        int countAll = jiGuangInfos.size();
        // 批次注册数
        int batchNum = 500;
        // 供需多少批
        int frequency = (countAll + batchNum -1) / batchNum;
        List<List<JiGuangInfo>> splitList = Stream.iterate(0, n -> n + 1) // 创建流
                .limit(frequency)    // 取 frequency 个
                .parallel()           // 开启并行处理
                .map(    // 处理单项
                        a -> jiGuangInfos.stream()
                        .skip(a * batchNum) // 跳过元素
                        .limit(batchNum)    // 取 batchNum 个
                        .parallel()        // 开启并行处理
                        .collect(Collectors.toList())
                )
                .collect(Collectors.toList());

 

List转为Map的方法有多种。其中一种方法是使用stream流的Collectors.toMap()方法。例如,可以通过对象的某个属性作为键,另外一个属性作为值,将List中的元素转为Map的键值对。代码示例如下: Map<Integer, String> map = list.stream() .collect(Collectors.toMap(Student::getAge, Student::getName)); 这段代码将List中的元素按照学生的年龄作为键,学生的姓名作为值,转换为一个Map对象。 还有其他几种方法可以实现List转Map的操作,包括处理键重复的情况、只返回对象中某个属性等。具体代码示例如下: - 第一种方法(可能会出现键重复异常): Map<Long, User> map = list.stream() .collect(Collectors.toMap(User::getId, Function.identity())); - 第二种方法(处理键重复情况): Map<Long, User> map = list.stream() .collect(Collectors.toMap(User::getId, Function.identity(), (key1, key2) -> key2)); - 第三种方法(只返回对象中某个属性): Map<Long, String> map = list.stream() .collect(Collectors.toMap(User::getId, User::getAge, (key1, key2) -> key2)); - 第四种方法(按某个属性分组): Map<Integer, List<User>> map = list.stream() .collect(Collectors.groupingBy(User::getId)); 每种方法都有不同的用途和适用场景,可以根据具体需求选择合适的方法来实现List转Map的操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [使用streamlist转成map](https://blog.csdn.net/Icannotdebug/article/details/78621705)[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: 50%"] - *2* [(stream流)List转Map](https://blog.csdn.net/lizaiismy/article/details/121352640)[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: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值