Lambda学习---StreamApi使用
package com.zx; import com.zx.entity.Book;
import org.junit.Test; import java.time.LocalDate;
import java.util.*;
import java.util.stream.Collectors;
import java.util.stream.Stream; /**
* StreamApi实战测试类
*
* @author ning
* @create 2018-06-12 9:25
**/
public class LambdaTest2 { @Test
public void test1(){
//将get参数解析成map
String str = "username=zhangsan&age=123&token=et34t423t4&key=f34t435y34&sigature=fsd043f4";
Map<String, String> collect3 = Stream.of(str.split("&")).map(x -> x.split("=")).collect(Collectors.toMap(a -> a[0], a -> a[1]));
System.out.println(collect3);
} @Test
public void test2(){
//将books的id转换成List<Integer>
List<Integer> collect = books().stream().map(Book::getId).collect(Collectors.toList());
System.out.println(collect);
}
@Test
public void test3(){
//将books的id取出用字符串拼接
//使用joining,参数必需先转成字符串
String collect = books().stream().map(x -> x.getId() + "").collect(Collectors.joining(","));
System.out.println(collect);
//使用joining,参数必需先转成字符串,还可以加括号
String collect1 = books().stream().map(x -> x.getId() + "").collect(Collectors.joining(",","(",")"));
System.out.println(collect1);
//使用joining,参数必需先转成字符串,还可以加括号,还可以加引号分割
String collect2 = books().stream().map(x -> "'" + x.getId() + "'").collect(Collectors.joining(",","(",")"));
System.out.println(collect2);
}
@Test
public void test4(){
//找出所有类型
List<String> collect = books().stream().map(Book::getType).collect(Collectors.toList());
System.out.println(collect);
//去重
List<String> collect1 = books().stream().map(Book::getType).distinct().collect(Collectors.toList());
System.out.println(collect1);
Set<String> collect2 = books().stream().map(Book::getType).collect(Collectors.toSet());
System.out.println(collect2);
} /**
* //排序
*/
@Test
public void test5(){ //1、根据价格
//Double.compare(b2.getPrice(), b1.getPrice()) 倒序
List<Book> collect = books().stream().sorted((b1, b2) -> Double.compare(b2.getPrice(), b1.getPrice())).collect(Collectors.toList());
System.out.println(collect);
// Double.compare(b1.getPrice(), b2.getPrice()) 正序
Comparator<Book> comp = (b1, b2) -> Double.compare(b1.getPrice(), b2.getPrice());
books().stream().sorted(comp).forEach(System.out::println);
System.out.println("--------------------------------------------------");
//另一种倒叙,使用Comparator的reversed()方法
books().stream().sorted(comp.reversed()).forEach(System.out::println);
System.out.println("--------------------------------------------------");
//多条件排序
//先根据价格排序,然后根据出版时间最近的排序
Comparator<Book> comp2 = (b1, b2) -> b1.getPublishDate().isAfter(b2.getPublishDate()) ? 1 : -1;
books().stream().sorted(comp.thenComparing(comp2)).forEach(System.out::println);
System.out.println("--------------------------------------------------");
books().stream().sorted(Comparator.comparing(Book::getPrice).thenComparing(Comparator.comparing(Book::getPublishDate).reversed())).forEach(System.out::println);
} @Test
public void test6(){
//将list集合转换成map,key是id,value是book对象
Map<Integer, Book> collect = books().stream().collect(Collectors.toMap(Book::getId, b -> b));
System.out.println(collect);
} /**
* 统计
*/
@Test
public void test7(){
//找出价格最贵的那本书
Book book = books().stream().collect(Collectors.maxBy(Comparator.comparing(Book::getPrice))).get();
System.out.println(book);
//找出价格最低的那本书
Book book1 = books().stream().collect(Collectors.minBy(Comparator.comparing(Book::getPrice))).get();
System.out.println(book1);
//找出出版日期最近的那本书
Book book2 = books().stream().collect(Collectors.maxBy(Comparator.comparing(Book::getPublishDate))).get();
System.out.println(book2);
//找到最大的价格
double max = books().stream().collect(Collectors.summarizingDouble(Book::getPrice)).getMax();
System.out.println(max);
//找到平均数
double v = books().stream().collect(Collectors.averagingDouble(Book::getPrice)).doubleValue();
System.out.println(v);
//找出价格最贵的那本书,如果不止一本,找到出版日期最近的那本
Book book3 = books().stream().collect(Collectors.maxBy(Comparator.comparing(Book::getPrice).thenComparing(Comparator.comparing(Book::getPublishDate)))).get();
System.out.println(book3);
//找出价格最贵的那本书,如果不止一本,找到出版日期最远的那本
Book book4 = books().stream().collect(Collectors.maxBy(Comparator.comparing(Book::getPrice).thenComparing(Comparator.comparing(Book::getPublishDate).reversed()))).get();
System.out.println(book4);
} /**
* 分组
*/
@Test
public void test8(){
//按照类型分组
Map<String, List<Book>> collect = books().stream().collect(Collectors.groupingBy(Book::getType));
collect.keySet().forEach(key -> {
System.out.println(key);
System.out.println(collect.get(key));
System.out.println("----------------------------------------------");
});
//统计每种类型有多少本书
Map<String, Long> collect1 = books().stream().collect(Collectors.groupingBy(Book::getType, Collectors.counting()));
System.out.println(collect1);
System.out.println("----------------------------------------------");
//单独统计编程语言有多少本
Long collect2 = books().stream().filter(book -> "编程语言".equals(book.getType())).collect(Collectors.counting());
System.out.println(collect2);
//统计每种类型数据的总价格,先分类,再按类型求和
Map<String, Double> collect3 = books().stream().collect(Collectors.groupingBy(Book::getType, Collectors.summingDouble(Book::getPrice)));
System.out.println(collect3);
//统计每种类型数据,先分类,再求每种类型的平均价格
Map<String, Double> collect4 = books().stream().collect(Collectors.groupingBy(Book::getType, Collectors.averagingDouble(Book::getPrice)));
System.out.println(collect4);
//统计每种类型数据,先分类,再求每种类型最贵的那本书
Map<String, Optional<Book>> collect5 = books().stream().collect(Collectors.groupingBy(Book::getType, Collectors.maxBy(Comparator.comparing(Book::getPrice))));
System.out.println(collect5);
System.out.println("----------------------------------------------");
collect5.keySet().forEach(key -> {
System.out.println(key);
System.out.println(collect5.get(key));
System.out.println("----------------------------------------------");
});
//统计每种类型数据,先分类,再求每种类型最便宜的那本书
Map<String, Optional<Book>> collect6 = books().stream().collect(Collectors.groupingBy(Book::getType, Collectors.minBy(Comparator.comparing(Book::getPrice))));
System.out.println(collect6);
System.out.println("----------------------------------------------");
collect6.keySet().forEach(key -> {
System.out.println(key);
System.out.println(collect6.get(key));
System.out.println("----------------------------------------------");
});
//统计每种类型数据,先分类,再求每种类型最晚出版的那本书
Map<String, Optional<Book>> collect7 = books().stream().collect(Collectors.groupingBy(Book::getType, Collectors.maxBy(Comparator.comparing(Book::getPublishDate))));
System.out.println(collect7);
System.out.println("----------------------------------------------");
collect7.keySet().forEach(key -> {
System.out.println(key);
System.out.println(collect7.get(key));
System.out.println("----------------------------------------------");
});
} /**
* 过滤
*/
@Test
public void test9(){
//过滤加排序
List<Book> collect = books().stream().filter(book -> book.getPrice() > 60).sorted(Comparator.comparing(Book::getPublishDate).reversed()).collect(Collectors.toList());
collect.forEach(System.out::println);
} List<Book> books(){
List<Book> books = new ArrayList<>();
books.add(new Book(1,"tomcat",50d,"服务器",LocalDate.parse("2016-10-01")));
books.add(new Book(2,"jetty",54d,"服务器",LocalDate.parse("2015-10-01")));
books.add(new Book(3,"nginx",54d,"服务器",LocalDate.parse("2014-12-01")));
books.add(new Book(4,"java",65d,"编程语言",LocalDate.parse("2011-04-01")));
books.add(new Book(5,"ruby",22d,"编程语言",LocalDate.parse("2016-01-01")));
books.add(new Book(6,"php",98d,"编程语言",LocalDate.parse("2016-10-25")));
books.add(new Book(7,"html",90d,"编程语言",LocalDate.parse("2002-10-11")));
books.add(new Book(8,"oracle",67d,"数据库",LocalDate.parse("2016-10-11")));
books.add(new Book(9,"mysql",34d,"数据库",LocalDate.parse("2012-10-01")));
books.add(new Book(10,"ssh",45d,"编程语言",LocalDate.parse("2013-10-01")));
books.add(new Book(11,"设计模式",56d,"其他",LocalDate.parse("2014-10-01")));
books.add(new Book(12,"代码重构",87d,"其他",LocalDate.parse("2015-10-01")));
books.add(new Book(13,"并发编程",34d,"其他",LocalDate.parse("2006-10-01")));
books.add(new Book(14,"spring源码分析",79d,"其他",LocalDate.parse("2016-05-01")));
books.add(new Book(15,"大型web项目实战",57d,"其他",LocalDate.parse("2016-10-07")));
books.add(new Book(16,"php2",98d,"编程语言",LocalDate.parse("2018-10-25")));
return books;
} }
Lambda学习---StreamApi使用的更多相关文章
- Java 8的Lambda学习
参考资料:https://www.dotnetperls.com/lambda-java Lambdas用于创建函数对象.通过它们,我们可以在其它方法内部指定方法,甚至可以把方法做为参数传递给其它方法 ...
- Lambda学习总结(三)--方法引用
一.方法引用 1.1 方法引用含义 在学习了 Lambda 表达式之后,我们通常会使用 Lambda 表达式来创建匿名方法.但有的时候我们仅仅是需要调用一个已存在的方法.如下示例: @Function ...
- Lambda学习---方法引用和其他基本应用
package com.zx; import java.util.*; import java.util.function.*; import java.util.stream.Collectors; ...
- Lambda学习总结(二)--Stream流
一.Stream 流 1.1 概念 官方解释:可以支持顺序和并行对元素操作的元素集合. 简单来讲,Stream 就是 JDK8 提供给我们的对于元素集合统一.快速.并行操作的一种方式. 它能充分运用多 ...
- Lambda学习总结(一)--函数式接口
Lambda 表达式是 JDK 1.8 里面的一个重要更新,这意味着 Java 也开始承认了函数式编程,并且尝试引入其中,我们今天就来了解下它的使用. 一.函数式接口 1.1 概念 函数式接口在 Ja ...
- Python的lambda学习
lambda可以简化简单循环,如下: def fc1(x): return x + 10 print "fc1(23) = ", fc1(23) y = lambda x: x+1 ...
- Java8 新特性 Lambda学习
import java.util.ArrayList;import java.util.Collections;import java.util.IntSummaryStatistics;import ...
- Java_静态代理与Lambda
静态代理 要点: 公共接口 真实角色 代理角色 public class StaticProxy { public static void main(String[] args) { You you ...
- python之路——17
王二学习python的笔记以及记录,如有雷同,那也没事,欢迎交流,wx:wyb199594 复习 1.迭代器2.生成器3.内置函数 1.学习55个 2.带key的,max min filter map ...
随机推荐
- sql求两表的并集、交集、非交集、差集、结果集排序
create table A( id ,) Not null primary key, name ) not null default(''), ) INSERT INTO [A]([name]) V ...
- .net 页面传参方式总结
一.使用Querystring Querystring是一种非常简单的传值方式,其缺点就是:安全性低.会把要传送的值显示在浏览器的地址栏中(也就是不需要保密得参数),并且在此方法中不能够传递对象,参数 ...
- [cb]NGUI事件及复杂UI管理
事件管理 看了有些文章关于NGUI的事件管理,许多人的做法的是封装一个事件处理层,避免在每个UI控件上都绑定事件处理脚本.本文说说我们项目中的UI事件管理吧. UIEventListener 我们项目 ...
- mysql数据库中导入txt文本数据的方法
安装好MySQL和Navicat 8 for MySQL 通过Navicat 8 for MySQL创建数据库test. 2 在数据库test上创建测试数据表student(主键ID,姓名,年龄,学 ...
- Qt分页导航控件
最近在使用QTableWidget时,因为结果数量比较多而且又有单元格控件,为了改善效率要做分页处理.在网上找了一番,最后在http://www.cppblog.com/biao/archive/20 ...
- 用apiDoc简化接口开发
身为程序员最讨厌看到的代码没有注释,自己的代码却讨厌写注释,觉得麻烦,接口也是这样. 比如公司要做一个H5活动的页面,开发文档已经发到后端开发.设计.与前端的邮箱了,其实这个时候就可以开始开发了.开发 ...
- AWS服务学习
什么是云计算? 云计算是用户通过Internet云服务平台按需提供计算能力.数据库存储.应用程序和其他IT资源,采用按需支付定价模式 无论您是在运行拥有数百万移动用户的照片共享应用程序,还是要为您的业 ...
- kudu基础入门
1.kudu介绍 1.1 背景介绍 在KUDU之前,大数据主要以两种方式存储: (1)静态数据: 以 HDFS 引擎作为存储引擎,适用于高吞吐量的离线大数据分析场景.这类存储的局限性是数据无法进行随机 ...
- saxbuilder用法
xml为我们在网络交换数据带来很大方便,在java中可以使用saxbuilder来操作xml格式文件,下面介绍一下saxbuilder的常用方法. import org.jdom.Document; ...
- HTML5中的Canvas详解
什么是Canvas HTML5 <canvas> 元素用于图形的绘制,通过脚本 (通常是JavaScript)来完成.<canvas> 标签只是图形容器,您必须使用脚本来绘制图 ...