函数式接口

  • 函数式接口:有且仅有一个抽象方法的接口。
  • 使用@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>: 输入是 TU 类型的数据,无返回值
  • BiPredicate<T, U>: 输入是 TU 类型的数据,返回 boolean 类型。
  • BiFunction<T, U, R>: 输入是 TU 类型的数据,返回 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常见函数式接口总结的更多相关文章

  1. java8的函数式接口

    函数式接口 就是在java8里允许你为一个接口(只有一个实现的,声明为FunctionalInterface注解的)实现一个匿名的对象,大叔感觉它与.net平台的委托很类似,一个方法里允许你接收一个方 ...

  2. JAVA8之函数式接口

    由于JDK8已经发布一段时间了,也开始逐渐稳定,未来使用JAVA语言开发的系统会逐渐升级到JDK8,因为为了以后工作需要,我们有必要了解JAVA8的一些新的特性.JAVA8相对JAVA7最重要的一个突 ...

  3. [译]Java8的函数式接口

    Java8引入了 java.util.function 包,他包含了函数式接口,具体的描述在以下api说明文档中: 函数式接口为lambda表达式和方法引用提供目标类型.每个函数式接口有一个单独的抽象 ...

  4. Java8 Functional(函数式接口)

    Functional 函数式(Functional)接口 只包含一个抽象方法的接口,称为函数式接口. 你可以通过 Lambda 表达式来创建该接口的对象.(若 Lambda 表达式抛出一个受检异常(即 ...

  5. java8 常用函数式接口

    public static void main(String[] args) { // TODO Auto-generated method stub //函数式接口 Function<Inte ...

  6. 乐字节-Java8核心特性实战之函数式接口

    什么时候可以使用Lambda?通常Lambda表达式是用在函数式接口上使用的.从Java8开始引入了函数式接口,其说明比较简单:函数式接口(Functional Interface)就是一个有且仅有一 ...

  7. java8学习之Supplier与函数式接口总结

    Supplier接口: 继续学习一个新的函数式接口--Supplier,它的中文意思为供应商.提供者,下面看一下它的javadoc: 而具体的方法也是相当的简单,就是不接受任何参数,返回一个结果: 对 ...

  8. java代码之美(14)---Java8 函数式接口

    Java8 函数式接口 之前写了有关JDK8的Lambda表达式:java代码之美(1)---Java8 Lambda 函数式接口可以理解就是为Lambda服务的,它们组合在一起可以让你的代码看去更加 ...

  9. java代码(14) --Java8函数式接口

    Java8函数式接口 之前有关JDK8的Lambda表达式 Java代码(1)--Java8 Lambda 函数式接口可以理解就是为Lambda服务的,它们组合在一起可以让你的代码看去更加简洁 一.概 ...

  10. Java8的新特性--函数式接口

    目录 函数式接口 什么是函数式接口 函数式接口的使用 Java8内置的四大核心函数式接口 一.Consumer:消费型接口(void accept(T t)) 二.Supplier:供给型接口(T g ...

随机推荐

  1. 【算法】Tarjan

    参考资料: 图论相关概念 - OI WIKI | 强连通分量 - OI WIKI 初探tarjan算法 | Tarjan,你真的了解吗 一.概念 • 子图: 对一张图 \(G=(V,E)\),若存在另 ...

  2. 通过URL保存文件

    1 <?php 2 3 function dlfile($file_url, $save_to) 4 { 5 $content = file_get_contents($file_url); 6 ...

  3. JSP脚本知识

    JSP脚本元素 1.在jsp中嵌入的服务端运行的小程序称为脚本.实质是java程序. 2.脚本元素可以分为三类:表达式.Scriptlet.声明. 表达式 计算java表达式的值,得到的结果转化为字符 ...

  4. springboot+thymeleaf中前台页面展示中、将不同的数字替换成不同的字符串。使用条件运算符

    主要用到的知识就是thyme leaf中的条件运算符 表达式:(condition)?:then:else 当条件condition成立时返回then.否则返回else 具体代码:<td th: ...

  5. C#实现生成Markdown文档目录树

    前言 之前我写了一篇关于C#处理Markdown文档的文章:C#解析Markdown文档,实现替换图片链接操作 算是第一次尝试使用C#处理Markdown文档,然后最近又把博客网站的前台改了一下,目前 ...

  6. JQuery中的DataTables表格插件

    一.DataTables表格插件的简介 DataTables是一个jQuery的表格插件.它具有以下特点: 自动分页处理 即时表格数据过滤 数据排序以及数据类型自动检测 自动处理列宽度 可通过CSS定 ...

  7. 一、什么是Kubernetes

    一.什么是Kubernetes ​它是一个全新的基于容器技术的分布式架构领先方案,确切地说,Kubernetes是谷歌严格保密十几年的秘密武器Borg的一个开源版本.Borg是谷歌内部使用的大规模集群 ...

  8. Python基础部分:1、typora软件和对计算机的认识

    目录 一.typora软件 1.安装 2.markdown语法 二.计算机的本质 1.进制数 三.计算机五大组成部分概要 1.控制器 2.运算器 3.存储器 4.输入设备 5.输出设备 一.typor ...

  9. 抠网页标题栏logo(图标)

    1.打开自己需要抠的网页,例如百度页面 2.在这个网页链接后面+" /favicon.ico " 就可以提取ico图片 3.回车进去,右键鼠标,选择另存为图片就可以成功保存网页中的 ...

  10. fastjson远程代码执行漏洞

    fastjson漏洞学习记录 免责声明: Fastjson 1.2.24 远程代码执行漏洞 漏洞说明 前提条件 影响范围 漏洞复现 Fastjson<=1.2.47 远程代码执行漏洞 Fastj ...