Stream流的常用方法[通俗易懂]

Stream流的常用方法[通俗易懂]1、快速创建ListListlist=Stream.of(“1″,”2”).collect(Collectors.toList());2、取对象的某一列低效方式:List<String>userNameList=newArrayList<>();for(String)List<String>userNameList=list.stream().map(User::getName).collect(Collectors.toList(

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

最近用了Stream流,感觉超好用,记录一下。

1、快速创建List

比如我有个实体类User,User有个属性Name
public class User { 
   
	public User(String name, String age, int height) { 
   
		this.name = name;
		this.age = age;
		this.height = height;
	}
	private String name;
	private String age;
	private int height;
	// setter、getter方法我就不写了
}

// 创建三个user
User user1 = new User("111", "18", 180);
User user2 = new User("222", "18", 175);
User user3 = new User("333", "19", 170);

现在我要创建3个user放到list中:

(1)、new一个list,一个一个添加
List<User> userList = new ArrayList<>();
userList.add(user1);
userList.add(user2);
userList.add(user3);
(2)、Stream流:创建动态list,可以添加元素
// stream流,创建的是动态数组,可以添加元素
List<User> userList = Stream.of(user1, user2, user3).collect(Collectors.toList());
(3)、如果创建一个固定长度的list,可以使用Arrays.asList(…args)直接返回一个list

本质是将一个数组转成list,数组的大小是固定的,所以此list不能添加元素,
如果调用add方法增加新的元素,会报异常:java.lang.UnsupportedOperationException
当元素是固定时,可以采用这个;

// 本质是将一个数组转成list,数组的大小是固定的,所以此list不能添加元素
// 如果调用add方法增加新的元素,会报异常:java.lang.UnsupportedOperationException
List<String> s = Arrays.asList("1","2","3") 

2、取对象的某一列:

拿上面userList举例,我取出list中所有user的name属性放到一个新的list中:

(1)、遍历
// 遍历
List<String> userNameList = new ArrayList<>();
for (User user : userList) { 
   
	userNameList.add(user.getName());
}
(2)、Stream流:map
// Stream流
List<String> userNameList = userList.stream().map(User::getName).collect(Collectors.toList());

3、过滤,或者说是根据一个判断条件筛选出目标对象

还拿上面的userList,比如我要筛选出userList中name不为空的user

(1)、遍历加 if
List<User> newUserList = new ArrayList<>();
// if判断
for (User user : userList) { 
   
	if(user.getName() != null) { 
   
		newUserList.add(user); 
	}
}
(2)、Stream流:filter
// 获取userName不为空的user的List
List<User> userList = userList.stream().filter(user-> user.getName() != null).collect(Collectors.toList());

4、分组

把userList中的user根据年龄分组:

(1)、遍历加 if
Map<String, List<User>> map = new HashMap<>();
// if判断
for (User user : userList) { 
   
	if (map.get(user.getAge()) == null) { 
   
		map.put(user.getAge(), new ArrayList());
	}
	map.get(user.getAge()).add(user);
}
(2)、Stream流:groupingBy
Map<String, List<User>> map =userList.stream().collect( Collectors.groupingBy(User::getAge, Collectors.toList()));

5、求和

(1)、int、double、long:

求和的普通遍历方式跟上面差不多,就不举例了;

// int、double、long:
double max = userList.stream().mapToDouble(User::getHeight).sum();

6、Map、List互转

(1)、list转map:
a、遍历:
	Map<String, User> userMap = new Map<>();
    for (User user : userList) { 
   
		userMap.put(user.getName(), user);
	}
b、stream流:

用Collectors的toMap方法转换List,一般会遇到两个问题。
(1)转换map,key重复问题;
代码中使用(key1,key2)->key2表达式可以解决此类问题,如果出现重复的key就使用key2覆盖前面的key1,也可以定义成(key1,key2)->key1,保留key1,根据自己的业务场景来调整。
(2)空指针异常,即转为map的value是null。这个可以用filter过滤;

	Map<String, User> userMap= userList.stream().collect(Collectors.toMap(User::getName, Function.identity(),(key1, key2)->key2));
(2)、map转list:
a、遍历:
	List<User> userList = new List<>();
    for (String userName : userMap.keySet()) { 
   
		userList.add(userMap.get(userName));
	}
b、stream流:
   List<User> userList = userMap.entrySet().stream().map(e ->e.getValue()).collect(Collectors.toList());

7、做判断

(1)、anyMatch():

判断的条件里,任意一个元素成功,返回true;
比如上面的userlList,我想判断是否有height > 175的:

    userList.stream().anyMatch(user -> user.getHeight() > 175);
(2)、allMatch():

allMatch:判断条件里的元素,所有的都是,返回true;
比如上面的userlList,我想判断是否全部height > 175的:

    userList.stream().allMatch(user -> user.getHeight() > 175);
(3)、noneMatch():

与allMatch相反,判断条件里的元素,所有的都不是,返回true

    userList.stream().noneMatch(user -> user.getHeight() > 175);
(4)、求取目标和:
    userList.stream().filter(user -> user.getHeight() > 175).count();
全部打印结果:
    System.out.println(userList.stream().anyMatch(user -> user.getHeight() > 175));
    System.out.println(userList.stream().allMatch(user -> user.getHeight() > 175));
    System.out.println(userList.stream().noneMatch(user -> user.getHeight() > 175));
    System.out.println(userList.stream().filter(user -> user.getHeight() > 175).count());

在这里插入图片描述

以上均为个人使用记录,若有错误,欢迎指正!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/185518.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Visio2013激活_2013 visio 32位

    Visio2013激活_2013 visio 32位转载的博客,记录下来,便于后面查找。from: http://blog.csdn.net/keenweiwei/article/details/42780805/环境是win7,64bit装了visio2013,可以却不能用它来画图,在网上找了一些激活成功教程工具,大都不能解决问题。网上不靠谱的广告型文章太多了,比较头痛。所幸,终于找到正确的激活成功教程工具KMSpico_set…

    2022年10月5日
    0
  • Java中的JPA是什么意思?「建议收藏」

    Java中的JPA是什么意思?「建议收藏」JPA(JavaPersistenceAPI),Java持久层API。它可以通过注解(JDK5.0)或者XML的方式描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中。它为POJO提供持久化标准规范,Hibernate3.2+、TopLink10.1.3以及OpenJPA都提供了JPA的实现它的总体思想和现有Hibernate、TopLink、JDO等ORM框架大体一致。它包括以下3方面的技术:(1)ORM映射元数据JPA支持XML和JDK5.0注解两种元.

    2022年6月29日
    28
  • Java设计模式(十五)之行为型模式:观察者模式

    Java设计模式(十五)之行为型模式:观察者模式

    2021年4月9日
    110
  • 但是生活总不是完美的

    但是生活总不是完美的里。为细水停留,为蔷薇伫足。水色清韵,一品天香,末指的时间,却觉不出暗香盈袖。输细水一分色,逊琼雪一段香。以晴翠为笔,以琼雪为墨。逸岭千城,踏雪无痕,末指的空间,却砌不出烟火人间。输晴翠一分情,逊琼雪只不过在寻求一种温暖的生存方式,可最后得到的并不是答案。高级别墅,奢华名车,并不是每一个进去的人都能快乐的,或许有了这些物质做依靠,总比什么都没有好许多,生活有时也仅仅只是一种形式,往往看到的只是外在

    2022年5月28日
    44
  • neokylin 系统_kdesk core service

    neokylin 系统_kdesk core service目录结构a) 文件和目录被组织成一个单根倒置的树状结构b) 文件系统从根目录下开始,用”/”表示c) 根文件系统(rootfs):rootfilesystemd) 文件名区分大小写(Windows中的文件系统不区分大小写)e) 以.开头的文件是隐藏文件f) 文件有两类数据i. 元数据:metadata用户描述文件本身的信息,也就是文件属性ii. 数据:data就是文件中存放的内容文件类型a) 蓝色表示目录d开头b) 黄色表示设备文件b开头:块设备c开头..

    2022年8月10日
    5
  • tomcat下载安装及配置教程视频_安装tomcat步骤

    tomcat下载安装及配置教程视频_安装tomcat步骤之前选择的版本是tomcat10.0按照下面流程走了一遍,发现一直是未发现的状态。后来,我换成了tomcat9版本就OK了下面以tomcat9.0版本为例讲述其过程

    2022年9月15日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号