JDK1.8 Stream流使用

​​​​​​​

一、概述

JDK1.8新增加流接口:java.util.stream.Stream。

所有集合Collection都可以使用 stream的默认方法获取流;获取数组对应的流,可以使用Stream接口的静态方法of。

二、Stream流的常用方法:filter、map、forEach、count、skip、limit、concat、sorted

java 复制代码
    @Test
	public void contextLoads() {
		List<User> list = buildUserList();
		  //list.forEach(System.out::println);
		//用map:把流中的元素映射到另一个流中,返回一个新的列表
		List<String> idList = list.stream().map(user -> {return user.getId();}).collect(Collectors.toList());
		System.out.println(JSON.toJSONString(idList));
		List<String> nameList = list.stream().map(user -> {return user.getName();}).collect(Collectors.toList());
		System.out.println(JSON.toJSONString(nameList));
        //过滤:filter,根据返回Boolean决定返回结果,返回一个新的列表
		List<User> uList = list.stream().filter(user -> user.getId().startsWith("A01")).collect(Collectors.toList());
		System.out.println(JSON.toJSONString(uList));
        //分页操作,从第2页开始取2条数据
		uList = list.stream().skip(1*2).limit(2).collect(Collectors.toList());
		System.out.println("分页::"+JSON.toJSONString(uList));
        //升序
		List<User> user_list = list.stream().sorted(Comparator.comparing(User::getId)).collect(Collectors.toList());
		System.out.println("升序排序::"+JSON.toJSONString(user_list));
		//降序
		user_list = list.stream().sorted(Comparator.comparing(User::getId).reversed()).collect(Collectors.toList());
		System.out.println("降序排序::"+JSON.toJSONString(user_list));
		//统计集合元素总数
		long count = list.stream().count();
		System.out.println("集合总数::"+count);
		//两个集合合并
		List<String> id_name_list=Stream.concat(idList.stream(),nameList.stream()).collect(Collectors.toList());
		System.out.println("列表合并::"+JSON.toJSONString(id_name_list));
	}
	
	private List<User> buildUserList(){
		List<User> list = new ArrayList<>();
		User user = null;
		for (int i=10;i<30;i++) {
			user = new User();
			user.setId("A0"+i);
			user.setName("ABD"+ LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyyMMddHHmmss")));
			list.add(user);
		}

		return list;
	}
相关推荐
迦蓝叶2 分钟前
JAiRouter 配置文件重构纪实 ——基于单一职责原则的模块化拆分与内聚性提升
java·网关·ai·重构·openai·prometheus·单一职责原则
ST.J4 分钟前
系统架构思考20241204
java·笔记·系统架构
TDengine (老段)23 分钟前
TDengine 时间函数 TIMETRUNCATE 用户手册
java·大数据·数据库·物联网·时序数据库·tdengine·涛思数据
给我个面子中不1 小时前
JUC、JVM八股补充
java·开发语言·jvm
mask哥2 小时前
详解flink性能优化
java·大数据·微服务·性能优化·flink·kafka·stream
hqxstudying2 小时前
Kafka 深入研究:从架构革新到性能优化的全面解析
java·开发语言·微服务·kafka·springcloud
失散133 小时前
并发编程——17 CPU缓存架构详解&高性能内存队列Disruptor实战
java·缓存·架构·并发编程
only-qi7 小时前
146. LRU 缓存
java·算法·缓存
xuxie139 小时前
SpringBoot文件下载(多文件以zip形式,单文件格式不变)
java·spring boot·后端
重生成为编程大王9 小时前
Java中的多态有什么用?
java·后端