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> /// < ...
随机推荐
- Spring Boot任务(定时,异步,邮件)
一.定时任务 开启定时任务(在Spring Boot项目主程序上添加如下注解) @EnableScheduling //开启定时任务的注解 创建定时任务(创建一个Service如下) @Service ...
- AIX中的页空间管理
1.页空间简介(Paging Space) 页空间是指硬盘上的存储内存信息的区域. 一个页空间也叫做一个交换空间. 是系统中一个类型为paging的逻辑卷. 2.创建页空间 使用mkps ...
- oracle 如何解锁表
--查询被锁的表 select b.owner,b.object_name,a.session_id,a.locked_mode from v$locked_object a,dba_objects ...
- 转(HBuilder 打包流程)
1.运行HBuilder---百度搜索HBuilder,官网下载安装包,解压,运行HBuilder.exe.注册账号,并登陆 2.新建app---在左边右键,选择新建APP,或者,点击中间的新建app ...
- javaIO--数据流之IO流与字节流
0.IO流 0.1.IO(Input Output)流的概念 Java中将不同设备之间的数据传输抽象为“流”:Stream设备指的是:磁盘上的文件,网络连接,另一个主机等等 按流向分:输入流,输出流: ...
- Vue3.0 Function API---------引用
1.了解 Vue 3.0 是否有 break change,就像 Python 3 / Angular 2 一样? 不,100% 兼容 Vue 2.0,且暂未打算废弃任何 API(未来也不).之前有草 ...
- C#调用Python(二)
python文件中有引入其他包.模块 一.源码 1.1 python源码,源码.python 打包方法,以及打包后的程序文件.请移步https://www.cnblogs.com/zhuanjiao ...
- spring自带工具类
在spring-core.jar包中,org.springframework.util package下有很多工具类,这些工具类十分具有参考意义.
- 文本框——EditText
长度
- IoC容器简介
官网说明: 在核心的第7章节 1 Spring IoC 容器和 beans 简介 本章介绍了 Spring Framework implementation of the Inversion of C ...