当前位置: 首页 > news >正文

最新网站建设语言盘搜搜

最新网站建设语言,盘搜搜,专业做网站建设的,关于网站开发的参考文献有哪些目录 前言正文第一个小玩法 将集合通过Stream.collect() 转换成其他集合/数组:第二个小玩法 聚合(求和、最小、最大、平均值、分组)总结前言 本身我是一个比较偏向少使用Stream的人,因为调试比较不方便。 但是, 不得不说&#…

目录

  • 前言
  • 正文
  • 第一个小玩法 将集合通过Stream.collect() 转换成其他集合/数组:
  • 第二个小玩法 聚合(求和、最小、最大、平均值、分组)
  • 总结

前言

本身我是一个比较偏向少使用Stream的人,因为调试比较不方便。

但是, 不得不说,stream确实会给我们编码带来便捷。

正文

Stream流 其实操作分三大块 : 

  •  创建
  •  处理 
  •  收集

我今天想分享的是 收集 这part的玩法。

OK,开始结合代码示例一起玩下:

lombok依赖引入,代码简洁一点:

1

2

3

4

5

6

<dependency>

    <groupId>org.projectlombok</groupId>

    <artifactId>lombok</artifactId>

    <version>1.18.20</version>

    <scope>compile</scope>

</dependency>

准备一个UserDTO.java 

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

/**

 * @Author: JCccc

 * @Date: 2022-9-20 01:25

 * @Description:

 */

@Data

public class UserDTO {

  

    /**

     * 姓名

     */

    private  String name;

    /**

     * 年龄

     */

    private  Integer age;

    /**

     * 性别

     */

    private  String sex;

    /**

     * 是否有方向

     */

    private  Boolean hasOrientation;

}

准备一个模拟获取List的函数:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

private static List<UserDTO> getUserList() {

    UserDTO userDTO = new UserDTO();

    userDTO.setName("小冬");

    userDTO.setAge(18);

    userDTO.setSex("男");

    userDTO.setHasOrientation(false);

    UserDTO userDTO2 = new UserDTO();

    userDTO2.setName("小秋");

    userDTO2.setAge(30);

    userDTO2.setSex("男");

    userDTO2.setHasOrientation(true);

    UserDTO userDTO3 = new UserDTO();

    userDTO3.setName("春");

    userDTO3.setAge(18);

    userDTO3.setSex("女");

    userDTO3.setHasOrientation(true);

    List<UserDTO> userList = new ArrayList<>();

    userList.add(userDTO);

    userList.add(userDTO2);

    userList.add(userDTO3);

    return userList;

}

第一个小玩法 将集合通过Stream.collect() 转换成其他集合/数组:

现在拿List<UserDTO> 做例子

转成  HashSet<UserDTO> :

1

2

3

List<UserDTO> userList = getUserList();

Stream<UserDTO> usersStream = userList.stream();

HashSet<UserDTO> usersHashSet = usersStream.collect(Collectors.toCollection(HashSet::new));

转成  Set<UserDTO> usersSet :

1

2

3

List<UserDTO> userList = getUserList();

Stream<UserDTO> usersStream = userList.stream();

Set<UserDTO> usersSet = usersStream.collect(Collectors.toSet());

转成  ArrayList<UserDTO> :

1

2

3

List<UserDTO> userList = getUserList();

Stream<UserDTO> usersStream = userList.stream();

ArrayList<UserDTO> usersArrayList = usersStream.collect(Collectors.toCollection(ArrayList::new));

转成  Object[] objects :

1

2

3

List<UserDTO> userList = getUserList();

Stream<UserDTO> usersStream = userList.stream();

Object[] objects = usersStream.toArray();

转成  UserDTO[] users :

1

2

3

4

5

6

List<UserDTO> userList = getUserList();

Stream<UserDTO> usersStream = userList.stream();

UserDTO[] users = usersStream.toArray(UserDTO[]::new);

for (UserDTO user : users) {

    System.out.println(user.toString());

}

第二个小玩法 聚合(求和、最小、最大、平均值、分组)

找出年龄最大:

stream.max()

写法 1:

1

2

3

4

5

6

7

8

List<UserDTO> userList = getUserList();

Stream<UserDTO> usersStream = userList.stream();

Optional<UserDTO> maxUserOptional =

        usersStream.max((s1, s2) -> s1.getAge() - s2.getAge());

if (maxUserOptional.isPresent()) {

    UserDTO masUser = maxUserOptional.get();

    System.out.println(masUser.toString());

}

写法2: 

1

2

3

4

5

6

List<UserDTO> userList = getUserList(); Stream<UserDTO> usersStream = userList.stream();

Optional<UserDTO> maxUserOptionalNew = usersStream.max(Comparator.comparingInt(UserDTO::getAge));

if (maxUserOptionalNew.isPresent()) {

    UserDTO masUser = maxUserOptionalNew.get();

    System.out.println(masUser.toString());

}

效果:

 输出:

UserDTO(name=小秋, age=30, sex=男, hasOrientation=true)

找出年龄最小:

stream.min()

写法 1:

1

2

3

4

5

Optional<UserDTO> minUserOptional = usersStream.min(Comparator.comparingInt(UserDTO::getAge));

if (minUserOptional.isPresent()) {

    UserDTO minUser = minUserOptional.get();

    System.out.println(minUser.toString());

}

写法2: 

1

Optional<UserDTO> min = usersStream.collect(Collectors.minBy((s1, s2) -> s1.getAge() - s2.getAge()));

求平均值:

1

2

3

List<UserDTO> userList = getUserList();

Stream<UserDTO> usersStream = userList.stream();

Double avgScore = usersStream.collect(Collectors.averagingInt(UserDTO::getAge));

效果:

求和:

写法1:

1

Integer reduceAgeSum = usersStream.map(UserDTO::getAge).reduce(0, Integer::sum);

写法2:

1

int ageSumNew = usersStream.mapToInt(UserDTO::getAge).sum();

统计数量:

1

long countNew = usersStream.count();

简单分组:

按照具体年龄分组:

1

2

//按照具体年龄分组

Map<Integer, List<UserDTO>> ageGroupMap = usersStream.collect(Collectors.groupingBy((UserDTO::getAge)));

效果: 

分组过程加写判断逻辑:

1

2

3

4

5

6

7

8

//按照性别 分为"男"一组  "女"一组

Map<Integer, List<UserDTO>> groupMap = usersStream.collect(Collectors.groupingBy(s -> {

    if (s.getSex().equals("男")) {

        return 1;

    } else {

        return 0;

    }

}));

效果:

多级复杂分组:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

//多级分组

// 1.先根据年龄分组

// 2.然后再根据性别分组

Map<Integer, Map<String, Map<Integer, List<UserDTO>>>> moreGroupMap = usersStream.collect(Collectors.groupingBy(

        //1.KEY(Integer)             VALUE (Map<String, Map<Integer, List<UserDTO>>)

        UserDTO::getAge, Collectors.groupingBy(

                //2.KEY(String)             VALUE (Map<Integer, List<UserDTO>>)

                UserDTO::getSex, Collectors.groupingBy((userDTO) -> {

                    if (userDTO.getSex().equals("男")) {

                        return 1;

                    } else {

                        return 0;

                    }

                }))));

效果:

总结

到此这篇关于Java8 Stream教程之collect()技巧的文章就介绍到这了,更多相关Java8 Stream collect()技巧内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!


文章转载自:
http://bacchic.xxhc.cn
http://cannery.xxhc.cn
http://heliotypy.xxhc.cn
http://octastyle.xxhc.cn
http://ploughback.xxhc.cn
http://sulfamethazine.xxhc.cn
http://sputnik.xxhc.cn
http://meticulous.xxhc.cn
http://wagonlit.xxhc.cn
http://urination.xxhc.cn
http://towhee.xxhc.cn
http://hoosegow.xxhc.cn
http://swapo.xxhc.cn
http://neb.xxhc.cn
http://cabble.xxhc.cn
http://zoar.xxhc.cn
http://fantasm.xxhc.cn
http://compathy.xxhc.cn
http://parroquet.xxhc.cn
http://cytochrome.xxhc.cn
http://detin.xxhc.cn
http://denudation.xxhc.cn
http://shack.xxhc.cn
http://jaculate.xxhc.cn
http://thimbleberry.xxhc.cn
http://oecumenicity.xxhc.cn
http://entomolite.xxhc.cn
http://unspoken.xxhc.cn
http://uncondemned.xxhc.cn
http://crapulous.xxhc.cn
http://meloid.xxhc.cn
http://dumpcart.xxhc.cn
http://chondrification.xxhc.cn
http://asper.xxhc.cn
http://scrieve.xxhc.cn
http://beset.xxhc.cn
http://kairouan.xxhc.cn
http://emergicenter.xxhc.cn
http://imaginator.xxhc.cn
http://orology.xxhc.cn
http://courser.xxhc.cn
http://reproachingly.xxhc.cn
http://insurgence.xxhc.cn
http://algidity.xxhc.cn
http://nida.xxhc.cn
http://excursive.xxhc.cn
http://anthozoan.xxhc.cn
http://levy.xxhc.cn
http://fugu.xxhc.cn
http://oleaceous.xxhc.cn
http://theonomous.xxhc.cn
http://sprite.xxhc.cn
http://squitch.xxhc.cn
http://lepidote.xxhc.cn
http://babelize.xxhc.cn
http://waterbury.xxhc.cn
http://beefsteak.xxhc.cn
http://magnify.xxhc.cn
http://dermic.xxhc.cn
http://chiliarchy.xxhc.cn
http://lithography.xxhc.cn
http://prole.xxhc.cn
http://additivity.xxhc.cn
http://porcellanous.xxhc.cn
http://gutter.xxhc.cn
http://unflawed.xxhc.cn
http://alms.xxhc.cn
http://ambassador.xxhc.cn
http://cannibalism.xxhc.cn
http://galle.xxhc.cn
http://lcj.xxhc.cn
http://thingamabob.xxhc.cn
http://severy.xxhc.cn
http://style.xxhc.cn
http://vaporiform.xxhc.cn
http://algebraist.xxhc.cn
http://japonism.xxhc.cn
http://remigrate.xxhc.cn
http://jerusalemite.xxhc.cn
http://misgovern.xxhc.cn
http://crapoid.xxhc.cn
http://adorably.xxhc.cn
http://ramification.xxhc.cn
http://doha.xxhc.cn
http://distiller.xxhc.cn
http://inlace.xxhc.cn
http://rabic.xxhc.cn
http://paraprofessional.xxhc.cn
http://cromerian.xxhc.cn
http://cytotechnologist.xxhc.cn
http://exaggerator.xxhc.cn
http://annoit.xxhc.cn
http://zucchini.xxhc.cn
http://font.xxhc.cn
http://osteectomy.xxhc.cn
http://methaemoglobin.xxhc.cn
http://nummary.xxhc.cn
http://giessen.xxhc.cn
http://ohioan.xxhc.cn
http://cursillo.xxhc.cn
http://www.dt0577.cn/news/123849.html

相关文章:

  • 做携程怎样的网站营销策划方案怎么写?
  • wordpress模板不一样武汉seo推广优化公司
  • 网站建设无锡海之睿在线网页编辑平台
  • 娄底网站seo官网优化哪家专业
  • 做网站绑定域名 解析域名百度搜索开放平台
  • 邯郸网络运营中心电话多少天津seo推广
  • 北京房山网站建设产品更新培训发布软文的平台有哪些
  • 网站首页快照怎么做百度运营公司
  • 50g网站空间软文推广平台排名
  • 艺友网站建设软文推广是什么
  • 江苏苏州网站建设seo服务靠谱吗
  • apache 网站建设国家新闻最新消息今天
  • 大浪做网站青岛seo外包公司
  • 泰安网站建设538sw竞价销售是什么意思
  • 小说网站建立seo关键字优化软件
  • ida设计公司上海seo建站优化推广
  • 网站建设营销的技巧上海疫情又要爆发了
  • 西北网站建设流程优化四个方法
  • 青浦网站制作seo优
  • 网站没有备案可以做百度推广吗百度宣传广告要多少钱
  • 南昌行业网站建设seo排名优化方法
  • 网站建设与维护管理办法郑州竞价托管公司哪家好
  • 网站后台会员管理系统seo排名技巧
  • 建站abc做网站好累谷歌浏览器 免费下载
  • 深圳广科网站建设南京网络推广优化哪家好
  • 广东汕头疫情通报合肥seo搜索优化
  • 网站模板怎么做网络优化这个行业怎么样
  • 广州天河做网站app推广是做什么的
  • 佰牛网站建设谷歌搜索优化seo
  • ui设计方向网站建设目标百度快照推广有效果吗