Java8常见函数式接口总结
函数式接口
- 函数式接口:有且仅有一个抽象方法的接口。
- 使用
@FunctionalInterface注解来标记。如果接口不是函数式接口就会编译出错 - 满足条件的接口即使不加上注解,那也是函数式接口
- 函数式接口可以作为方法的参数
public static void main(String[] args) {
// 1. 匿名类作为参数
startThread(new Runnable() {
@Override
public void run() {
System.out.println(Thread.currentThread().getName());
}
});
// 2. 函数式接口作为参数
startThread(() -> System.out.println(Thread.currentThread().getName()));
} public static void startThread(Runnable r){
new Thread(r).start();
}
- 函数式接口可以作为方法的返回值
public static void main(String[] args) {
// 函数式接口作为返回值
List<String> list = new ArrayList<>();
list.add("aa");
list.add("bbbbb");
list.add("c"); System.out.println(list);
Collections.sort(list, getComparator());
System.out.println(list);
} public static Comparator<String> getComparator(){
// 1. 直接新建匿名对象
// Comparator<String> comp = new Comparator<String>() {
// @Override
// public int compare(String o1, String o2) {
// return o1.length() - o2.length();
// }
// };
// return comp; // 2. 使用lambda
Comparator<String> comp = (o1, o2) -> o1.length() - o2.length();
return comp;
}
常用的函数式接口
Supplier<T>: 没有输入,返回一个T类型的结果。Consumer<T>: 输入一个T类型参数,没有返回值。Predicate<T>: 输入一个T类型参数,返回boolean。Function<T, R>: 输入一个T类型参数,返回R类型参数。
对应的还有两个参数的版本:
BiConsumer<T, U>: 输入是T和U类型的数据,无返回值BiPredicate<T, U>: 输入是T和U类型的数据,返回boolean类型。BiFunction<T, U, R>: 输入是T和U类型的数据,返回R类型。
Function<T, R> 接口
@FunctionalInterface
public interface Function<T, R> {
// 输入T类型参数,输出R类型结果
R apply(T t);
// 返回一个新的Function。先执行before,再执行当前
default <V> Function<V, R> compose(Function<? super V, ? extends T> before) {
Objects.requireNonNull(before);
return (V v) -> apply(before.apply(v));
}
// 返回一个新的Function。限制性当前,再执行after
default <V> Function<T, V> andThen(Function<? super R, ? extends V> after) {
Objects.requireNonNull(after);
return (T t) -> after.apply(apply(t));
}
static <T> Function<T, T> identity() {
return t -> t;
}
}
Function<String, String> func1 = (x) -> x + "1";
Function<String, String> func2 = (x) -> x + "2";
System.out.println(func1.apply("0")); // 01
System.out.println(func1.andThen(func2).apply("0")); // 012
System.out.println(func1.compose(func2).apply("0")); // 021
Consumer<T> 接口
@FunctionalInterface
public interface Consumer<T> {
void accept(T t);
default Consumer<T> andThen(Consumer<? super T> after) {
Objects.requireNonNull(after);
return (T t) -> { accept(t); after.accept(t); };
}
}
Consumer<StringBuilder> consumer = (x) -> {
x.append("1");
};
StringBuilder str = new StringBuilder("0");
consumer.accept(str);
System.out.println(str.toString()); // 01
Supplier<T> 接口
@FunctionalInterface
public interface Supplier<T> {
// 获取一个元素
T get();
}
lambda可捕获局部变量
// Suplier
Supplier<String> supplier = () -> "aaa";
System.out.println(supplier.get());
// 使用外部变量
int arr [] = {20, 40, 30, 10};
Supplier<Integer> getMax = ()-> {
int max_ = arr[0];
for (int item : arr){
if (item > max_) max_ = item;
}
return max_;
};
System.out.println(getMax.get());
Predicate<T> 接口
@FunctionalInterface
public interface Predicate<T> {
// 输入一个t,返回boolean
boolean test(T t);
// 与运算
default Predicate<T> and(Predicate<? super T> other) {
Objects.requireNonNull(other);
return (t) -> test(t) && other.test(t);
}
// 取反运算
default Predicate<T> negate() {
return (t) -> !test(t);
}
// 或运算
default Predicate<T> or(Predicate<? super T> other) {
Objects.requireNonNull(other);
return (t) -> test(t) || other.test(t);
}
static <T> Predicate<T> isEqual(Object targetRef) {
return (null == targetRef)
? Objects::isNull
: object -> targetRef.equals(object);
}
}
// Predicate
Predicate<String> predicate = (x)-> x.contains("0");
Predicate<String> predicate2 = (x) -> x.contains("1");
System.out.println(predicate.test("0123")); // true
System.out.println(predicate.negate().test("0000")); // false
System.out.println(predicate.and(predicate2).test("0123")); // true
System.out.println(predicate.or(predicate2).test("0000")); // true
Java8常见函数式接口总结的更多相关文章
- java8的函数式接口
函数式接口 就是在java8里允许你为一个接口(只有一个实现的,声明为FunctionalInterface注解的)实现一个匿名的对象,大叔感觉它与.net平台的委托很类似,一个方法里允许你接收一个方 ...
- JAVA8之函数式接口
由于JDK8已经发布一段时间了,也开始逐渐稳定,未来使用JAVA语言开发的系统会逐渐升级到JDK8,因为为了以后工作需要,我们有必要了解JAVA8的一些新的特性.JAVA8相对JAVA7最重要的一个突 ...
- [译]Java8的函数式接口
Java8引入了 java.util.function 包,他包含了函数式接口,具体的描述在以下api说明文档中: 函数式接口为lambda表达式和方法引用提供目标类型.每个函数式接口有一个单独的抽象 ...
- Java8 Functional(函数式接口)
Functional 函数式(Functional)接口 只包含一个抽象方法的接口,称为函数式接口. 你可以通过 Lambda 表达式来创建该接口的对象.(若 Lambda 表达式抛出一个受检异常(即 ...
- java8 常用函数式接口
public static void main(String[] args) { // TODO Auto-generated method stub //函数式接口 Function<Inte ...
- 乐字节-Java8核心特性实战之函数式接口
什么时候可以使用Lambda?通常Lambda表达式是用在函数式接口上使用的.从Java8开始引入了函数式接口,其说明比较简单:函数式接口(Functional Interface)就是一个有且仅有一 ...
- java8学习之Supplier与函数式接口总结
Supplier接口: 继续学习一个新的函数式接口--Supplier,它的中文意思为供应商.提供者,下面看一下它的javadoc: 而具体的方法也是相当的简单,就是不接受任何参数,返回一个结果: 对 ...
- java代码之美(14)---Java8 函数式接口
Java8 函数式接口 之前写了有关JDK8的Lambda表达式:java代码之美(1)---Java8 Lambda 函数式接口可以理解就是为Lambda服务的,它们组合在一起可以让你的代码看去更加 ...
- java代码(14) --Java8函数式接口
Java8函数式接口 之前有关JDK8的Lambda表达式 Java代码(1)--Java8 Lambda 函数式接口可以理解就是为Lambda服务的,它们组合在一起可以让你的代码看去更加简洁 一.概 ...
- Java8的新特性--函数式接口
目录 函数式接口 什么是函数式接口 函数式接口的使用 Java8内置的四大核心函数式接口 一.Consumer:消费型接口(void accept(T t)) 二.Supplier:供给型接口(T g ...
随机推荐
- Linux基础_5_文件管理
创建 touch 文件名 #创建文件 stat 文件名 #查看文件属性 touch -am 文件名 #更改文件的访问时间及修改时间 删除 rm -rf s/* #递归强制删除s目录下的所有内容(包括文 ...
- python关于Django搭建简单博客项目 详解二-setting.py
这一篇我们来讲解setting.py,具体内容以注释形式写入到下面的setting.py代码中,篇幅所限已把官方所给英文注释删除. 全部源代码和详解请参看http://github.com/Cheng ...
- 【性能测试】Loadrunner12.55(二)-飞机订票系统-脚本录制
1.1 飞机订票系统 Loadrunner 12.55不会自动安装飞机订票系统,要自己手动安装. 我们需要下载Web Tools以及一个小插件strawberry https://marketplac ...
- Kubeadm部署Kubernetes
Kubeadm部署Kubernetes 1.环境准备 主机名 IP 说明 宿主机系统 k8s-master 10.0.0.101 Kubernetes集群的master节点 Ubuntu2004 k8 ...
- Appscan安全扫描问题-会话检测失败
在进行手动探索-使用浏览器记录时,在后续的继续探索中经常碰到会话检测失败的问题.然而在[配置-登录管理-自动]中记录账号密码后再继续探索仍然提示会话检测失败....网上查找了资料,从该博主的博文中成功 ...
- ModuleNotFoundError: No module named 'XXX'
先来一张表情包: pycharm在小黑框使用pip安装某个包,在解释器没有找到某个包,所以运行程序的时候总是报错. 我相信大家可能都遇到这样的问题. 我下载有3.8.3.10版本的python,我py ...
- Unity之"诡异"的协程
为什么说是诡异的协程呢?首先从一个案例说起吧,示例如下: 游戏目标:让小车进入到对应颜色屋子里,即可获得一分.(转弯的道路可控) 为了让小车能够平滑转弯,小车的前进方向需要和车子的位置与圆心组成的 ...
- c语言内存四区、数据存储范围和内存存储方向
(1)代码区通常是共享只读(代码无法修改)的,即可以被其他的程序调用,例如运行两个qq,除了数据不一样,代码都是一样的, 每次运行qq,都会将代码和数据加载到内存中,除了数据,每次加载的代码都是一样的 ...
- php 高并发
1 swoole的博客 http://rango.swoole.com/archives/508 2 消息队列 3 接口并发请求
- ssh免交互
sshpass -p the_password ssh -o StrictHostKeyChecking=no root@domainname_or_ip remote_command #远程执行命 ...