lambda表达式使用解析
1、Predicate/Consumer/Function/Supplier介绍
Predicate boolean test(T t);
Consumer accpet(T t);
Function<T, R> R apply(T t);
Supplier<T> T get();
以Predicate为例,引申出很多类似的Predicate,如IntPredicate、DoublePredicate、BiPredicate、LongPredicate。但是他们的用法都是差不多的。比较类似。
2、举例子:
package com.cy.java8; import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.function.*; public class LambdaUsage { private static List<Apple> filter(List<Apple> source, Predicate<Apple> predicate){
List<Apple> result = new ArrayList<>();
for(Apple a : source){
if(predicate.test(a)){
result.add(a);
}
}
return result;
} //根据一个long类型的参数过滤
private static List<Apple> filterByWeight(List<Apple> source, LongPredicate predicate){
List<Apple> result = new ArrayList<>();
for(Apple a : source){
if(predicate.test(a.getWeight())){
result.add(a);
}
}
return result;
} //根据两个参数过滤
private static List<Apple> filterByColorWeight(List<Apple> source, BiPredicate<String, Long> bipredicate){
List<Apple> result = new ArrayList<>();
for(Apple a : source){
if(bipredicate.test(a.getColor(), a.getWeight())){
result.add(a);
}
}
return result;
} private static void simpleTestConsumer(List<Apple> source, Consumer<Apple> consumer){
for(Apple a : source){
consumer.accept(a);
}
} private static String testFunction(Apple apple, Function<Apple, String> fun){
return fun.apply(apple);
} public static void main(String[] args) {
List<Apple> list = Arrays.asList(new Apple("green", 120), new Apple("red", 150));
List<Apple> greenList = filter(list, apple -> apple.getColor().equals("green"));
System.out.println(greenList); System.out.println("-----------------------------");
List<Apple> weightList = filterByWeight(list, weight -> weight>=150);
System.out.println(weightList); System.out.println("-----------------------------");
List<Apple> result = filterByColorWeight(list, (color, weight) -> color.equals("red") && weight > 100);
System.out.println(result); System.out.println("-----------------------------");
simpleTestConsumer(list, apple -> System.out.println("print apple's string method: " +apple)); System.out.println("-----------------------------");
String color = testFunction(new Apple("yellow", 10), apple -> apple.getColor());
System.out.println(color); System.out.println("-----------------------------");
Supplier<String> supplier = String::new;
System.out.println(supplier.get().getClass());
} }
打印结果:
[Apple(color=green, weight=120)]
-----------------------------
[Apple(color=red, weight=150)]
-----------------------------
[Apple(color=red, weight=150)]
-----------------------------
print apple's string method: Apple(color=green, weight=120)
print apple's string method: Apple(color=red, weight=150)
-----------------------------
yellow
-----------------------------
class java.lang.String
3、方法推导解析
什么情况下允许方法推导的方式来写呢?
1.可以通过一个类的静态方法,比如Integer::parseInt
2.可以通过一个类的成员方法。
3.可以通过一个类的实例的方法。
4.可以通过构造函数的推导。
举例子:
package com.cy.java8; import lombok.Data; @Data
public class ComplexApple {
private String color;
private long weight;
private String name; public ComplexApple(String color, long weight, String name) {
this.color = color;
this.weight = weight;
this.name = name;
}
}
package com.cy.java8; @FunctionalInterface
public interface ThreeParamFuntion<T, U, K, R> { R apply(T t, U u, K k);
}
package com.cy.java8; import java.util.Arrays;
import java.util.Comparator;
import java.util.List;
import java.util.function.BiFunction;
import java.util.function.Consumer;
import java.util.function.Function;
import java.util.function.Supplier;
import java.util.stream.Stream; public class MethodReference { public static void main(String[] args) {
/*Consumer<String> consumer = s -> System.out.println(s);
useConsumer(consumer,"hello alex");*/ useConsumer(s -> System.out.println(s),"hello alex");
useConsumer(System.out::println, "hello today"); List<Apple> list = Arrays.asList(new Apple("green", 120), new Apple("abc", 100), new Apple("red", 150));
System.out.println(list);
list.sort((a1, a2) -> a1.getColor().compareTo(a2.getColor()));
System.out.println(list); //比如循环输出apple信息
list.stream().forEach(apple -> System.out.println(apple)); //可以改成成如下
System.out.println("-----------------------------------------");
list.stream().forEach(System.out::println);
System.out.println("-----------------------------------------"); //方法推导,通过一个类的静态方法
Function<String, Integer> funtion = Integer::parseInt;
int result = funtion.apply("123");
System.out.println(result); //方法推导,通过一个类的成员方法
BiFunction<String, Integer, Character> f1 = String::charAt;
System.out.println(f1.apply("index", 0)); //方法推导,通过一个类的实例的方法
String s = new String("index");
Function<Integer, Character> f2 = s::charAt;
System.out.println(f2.apply(1)); //通过构造函数的推导
Supplier<String> s1 = String::new;
System.out.println(s1.get().getClass().getSimpleName()); BiFunction<String, Long, Apple> biFunction = Apple::new;
System.out.println(biFunction.apply("pink", 2L)); //三个参数的构造方法,ComplexApple::new,需要自己定义FunctionalInterface
ThreeParamFuntion<String, Long, String, ComplexApple> threeParamFuntion = ComplexApple::new;
System.out.println(threeParamFuntion.apply("black", 1L, "blackApple")); //再次看下上面list的排序的另一种方法
List<Apple> list2 = Arrays.asList(new Apple("green", 120), new Apple("abc", 100), new Apple("red", 150));
list2.sort(Comparator.comparing(Apple::getColor));
System.out.println(list2);
} private static <T> void useConsumer(Consumer<T> consumer, T t){
consumer.accept(t);
consumer.accept(t);
} }
打印如下:
hello alex
hello alex
hello today
hello today
[Apple(color=green, weight=120), Apple(color=abc, weight=100), Apple(color=red, weight=150)]
[Apple(color=abc, weight=100), Apple(color=green, weight=120), Apple(color=red, weight=150)]
Apple(color=abc, weight=100)
Apple(color=green, weight=120)
Apple(color=red, weight=150)
-----------------------------------------
Apple(color=abc, weight=100)
Apple(color=green, weight=120)
Apple(color=red, weight=150)
-----------------------------------------
123
i
n
String
Apple(color=pink, weight=2)
ComplexApple(color=black, weight=1, name=blackApple)
[Apple(color=abc, weight=100), Apple(color=green, weight=120), Apple(color=red, weight=150)]
lambda表达式使用解析的更多相关文章
- Lambda表达式树解析(下)
概述 前面章节,总结了Lambda树的构建,那么怎么解析Lambda表达式树那?Lambda表达式是一种委托构造而成,如果能够清晰的解析Lambda表达式树,那么就能够理解Lambda表达式要传递的正 ...
- Lambda表达式树解析(下)包含自定义的provider和查询
概述 前面章节,总结了Lambda树的构建,那么怎么解析Lambda表达式树那?Lambda表达式是一种委托构造而成,如果能够清晰的解析Lambda表达式树,那么就能够理解Lambda表达式要传递的正 ...
- 今夜我懂了Lambda表达式_解析
现在时间午夜十一点~ 此刻的我血脉喷张,异常兴奋:因为专注得学习了一把java,在深入集合的过程中发现好多套路配合Lambda表达式真的是搜椅子,so开了个分支,决定从"只认得", ...
- Python 中Lambda 表达式 实例解析
Lambda 表达式 lambda表达式是一种简洁格式的函数.该表达式不是正常的函数结构,而是属于表达式的类型.而且它可以调用其它函数. 1.基本格式: lambda 参数,参数...:函数功能代码 ...
- C++11 Lambda表达式简单解析
C++11 新增了非常多特性,lambda 表达式是当中之中的一个.假设你想了解的 C++11 完整特性, 建议去http://www.open-std.org/看看新标准! 非常多语言都提供了 la ...
- SqlHelper简单实现(通过Expression和反射)5.Lambda表达式解析类
这个ExpressionHelper类,是整个SqlHelper中,最核心的一个类,主要功能就是将Lambda表达式转换为Sql语句.同时这个转换过程比较复杂,所以下面详细讲解一下思路和这个类的作用. ...
- python函数,lambda表达式,三目运算,列表解析,递归
一.自定义函数 定义函数时,函数体不执行:只有在调用函数时,函数体才执行.函数的结构: 1. def 2. 函数名 3. 函数体 def func_name(): 函数体 4. 返回值 如果没有声明返 ...
- 解析 Lambda 表达式
我们先创建一个表达式树: Expression<Func<int, int, int>> expression = (a,b) => a + b; 我们的例子是一个Exp ...
- 将Lambda表达式作为参数传递并解析-在构造函数参数列表中使用Lambda表达式
public class DemoClass { /// <summary> /// 通过Lambda表达式,在构造函数中赋初始值 /// </summary> /// < ...
随机推荐
- PDF转图片,在线PDF转JPG/PNG
[在线DEMO](https://oktools.net/pdf2img) 原理 使用pdf.js预览图片,pdf.js将pdf通过canvas将每一页渲染出来,然后我们通过canvas的toData ...
- linux上安装Eclipse
之所以要在linux上安装Eclipse,是因为一开始我是通过Eclipse+MingW+Samba+GDBserver方式在Windows上远程操作,准备编译调试nginx源代码的,可是在编译调试过 ...
- Linux20期学习笔记 Day4
环境变量.常用系统变量:vim编辑器使用方法及实验:shell脚本两个层次 内置参数及相关实验
- 机器学习聚类算法之DBSCAN
一.概念 DBSCAN是一种基于密度的聚类算法,DBSCAN需要两个参数,一个是以P为中心的邻域半径:另一个是以P为中心的邻域内的最低门限点的数量,即密度. 优点: 1.不需要提前设定分类簇数量,分类 ...
- 转(HBuilder 打包流程)
1.运行HBuilder---百度搜索HBuilder,官网下载安装包,解压,运行HBuilder.exe.注册账号,并登陆 2.新建app---在左边右键,选择新建APP,或者,点击中间的新建app ...
- 洛谷P3374 【模板】树状数组 1&&P3368 【模板】树状数组 2题解
图片来自度娘~~ 树状数组形如上图,是一种快速查找区间和,快速修改的一种数据结构,一个查询和修改复杂度都为log(n),树状数组1和树状数组2都是板子题,在这里进行详解: 求和: 首先我们看一看这个图 ...
- Vue框架使用sass
引入: cnpm install node-sass --save-dev //安装node-sass cnpm install sass-loader@7.3.1 --save-dev cnpm i ...
- Python 时间序列
Python - 时间处理模块 datetime - 常用模块 官方文档 time calendar
- Docker(五):Dockerfile
我们使用 Dockerfile 定义镜像,依赖镜像来运行容器,因此 Dockerfile 是镜像和容器的关键,Dockerfile 可以非常容易的定义镜像内容,同时在我们后期的微服务实践中,Docke ...
- Hadoop2.7.4 yarn(HA)集群搭建步骤(CentOS7)
群节点分配: Park01:Zookeeper.NameNode(active).ResourceManager(active) Park02:Zookeeper.NameNode(standby) ...