评论

收藏

[Java] 浅谈Java 8 新增函数式接口到底是什么

编程语言 编程语言 发布于:2021-10-06 12:18 | 阅读数:569 | 评论:0

这篇文章主要介绍了浅谈Java 8 新增函数式接口到底是什么,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
从 java 8 开始便出现了函数式接口(functional interface,以下简称fi)
定义为: 如果一个接口只有唯一的一个抽象接口,则称之为函数式接口。为了保证接口符合 fi ,通常会在接口类上添加 @functionalinterface 注解。理解了函数式接口可以为 java 函数式编程打下基础,最终可通过运用函数式编程极大地提高编程效率。
函数式接口 (functional interface) 就是一个有且仅有一个抽象方法,但是可以有多个非抽象方法的接口。
函数式接口可以对现有的函数友好地支持 lambda。
jdk 1.8 之前已有的函数式接口:

  • java.lang.runnable
  • java.util.concurrent.callable
  • java.security.privilegedaction
  • java.util.comparator
  • java.io.filefilter
  • java.nio.file.pathmatcher
  • java.lang.reflect.invocationhandler
  • java.beans.propertychangelistener
  • java.awt.event.actionlistener
  • javax.swing.event.changelistener
jdk 1.8 新增加的函数接口:

  • java.util.function
网上很多教程说新增 4 个函数接口是不对的,java.util.function 它包含了很多类,用来支持 java的 函数式编程,该包中的函数式接口 43 个,但是最主要的是这四个:
(1)功能性接口:function<t,r>
(2)断言性接口:predicate<t>
(3)供给性接口:supplier<t>
(4)消费性接口:consumer<t>
详细一点介绍:
函数式接口参数类型返回类型用途consumertvoid对类型t参数操作,无返回结果,包含方法 void accept(t t)supplier无t返回t类型参数,方法时 t get()functiontr对类型t参数操作,返回r类型参数,包含方法 r apply(t t)predicatetboolean断言型接口,对类型t进行条件筛选操作,返回boolean,包含方法 boolean test(t t)具体的使用:
/**
 * java8内置的四大核心函数式接口:
 * consumer<t>:消费型接口</t>
 * supplier<t>供给型接口</t>
 * function<t,r>函数型接口</t,r>
 * predicate<t>段言型接口</t>
 * boolean test(t t)
 */
 
public class testlamda3 {
 
  //consumer<t>
  @test
  public void test1(){
  happy(10000,(m)-> system.out.println("这次消费了"+m+"元"));
  }
 
  public void happy(double money, consumer<double> con){
  con.accept(money);
  }
 
  //supplier<t>
  @test
  public void test2(){
   list<integer> list=  getnumlist(5,()->{
    return (int)math.random()*100;
  });
   list.foreach(system.out::println);
  }
 
  public list<integer> getnumlist(int num, supplier<integer> supplier){
   list<integer> list=new arraylist<>();
   for (int i=0; i<num;i++){
     integer n=supplier.get();
     list.add(n);
   }
   return list;
  }
 
  //函数式接口
  @test
  public void test4(){
   string newstr=strhandle("\t\t\t woshi nide ",(str)->str.trim());
   system.out.println(newstr);
  }
 
  public string strhandle(string str,function<string,string> fun){
   return fun.apply(str);
  }
 
  //段言型接口;将满足条件的字符串放入集合中
  @test
  public void test5(){
  list<string> list1= arrays.aslist("nihao","hiehei","woai","ni");
  list<string> list=filterstr(list1,(s)->s.length()>3);
  for (string s : list) {
    system.out.println(s);
  }
  }
  public list<string> filterstr(list<string> list, predicate<string> pre){
  list<string> strings=new arraylist<>();
  for (string string : list) {
    if(pre.test(string)){
    strings.add(string);
    }
  }
  return strings;
  }
}
全部接口:
序号接口 & 描述1biconsumer<t,u>代表了一个接受两个输入参数的操作,并且不返回任何结果
2bifunction<t,u,r>代表了一个接受两个输入参数的方法,并且返回一个结果
3binaryoperator<t>代表了一个作用于于两个同类型操作符的操作,并且返回了操作符同类型的结果
4bipredicate<t,u>代表了一个两个参数的boolean值方法
5booleansupplier代表了boolean值结果的提供方
6consumer<t>代表了接受一个输入参数并且无返回的操作
7doublebinaryoperator代表了作用于两个double值操作符的操作,并且返回了一个double值的结果。
8doubleconsumer代表一个接受double值参数的操作,并且不返回结果。
9doublefunction<r>代表接受一个double值参数的方法,并且返回结果
10doublepredicate代表一个拥有double值参数的boolean值方法
11doublesupplier代表一个double值结构的提供方
12doubletointfunction接受一个double类型输入,返回一个int类型结果。
13doubletolongfunction接受一个double类型输入,返回一个long类型结果
14doubleunaryoperator接受一个参数同为类型double,返回值类型也为double 。
15function<t,r>接受一个输入参数,返回一个结果。
16intbinaryoperator接受两个参数同为类型int,返回值类型也为int 。
17intconsumer接受一个int类型的输入参数,无返回值 。
18intfunction<r>接受一个int类型输入参数,返回一个结果 。
19intpredicate接受一个int输入参数,返回一个布尔值的结果。
20intsupplier无参数,返回一个int类型结果。
21inttodoublefunction接受一个int类型输入,返回一个double类型结果 。
22inttolongfunction接受一个int类型输入,返回一个long类型结果。
23intunaryoperator接受一个参数同为类型int,返回值类型也为int 。
24longbinaryoperator接受两个参数同为类型long,返回值类型也为long。
25longconsumer接受一个long类型的输入参数,无返回值。
26longfunction<r>接受一个long类型输入参数,返回一个结果。
27longpredicater接受一个long输入参数,返回一个布尔值类型结果。
28longsupplier无参数,返回一个结果long类型的值。
29longtodoublefunction接受一个long类型输入,返回一个double类型结果。
30longtointfunction接受一个long类型输入,返回一个int类型结果。
31longunaryoperator接受一个参数同为类型long,返回值类型也为long。
32objdoubleconsumer<t>接受一个object类型和一个double类型的输入参数,无返回值。
33objintconsumer<t>接受一个object类型和一个int类型的输入参数,无返回值。
34objlongconsumer<t>接受一个object类型和一个long类型的输入参数,无返回值。
35predicate<t>接受一个输入参数,返回一个布尔值结果。
36supplier<t>无参数,返回一个结果。
37todoublebifunction<t,u>接受两个输入参数,返回一个double类型结果
38todoublefunction<t>接受一个输入参数,返回一个double类型结果
39tointbifunction<t,u>接受两个输入参数,返回一个int类型结果。
40tointfunction<t>接受一个输入参数,返回一个int类型结果。
41tolongbifunction<t,u>接受两个输入参数,返回一个long类型结果。
42tolongfunction<t>接受一个输入参数,返回一个long类型结果。
43unaryoperator<t>接受一个参数为类型t,返回值类型也为t。
总结
函数式接口 (functional interface) 就是一个有且仅有一个抽象方法,但是可以有多个非抽象方法的接口。
函数式接口是为了 lambda 表达式服务,函数式接口的存在是 lambda 表达式出现的前提,lambda 表达式想关于重写了函数式接口中的唯一方法。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持CodeAE代码之家
原文链接:https://blog.csdn.net/qq_40147863/article/details/85085153

关注下面的标签,发现更多相似文章