1. 函数式接口的理解
根据重构的思想,需要把容易变化的模块进行抽象并封装起来,从这个点来看,Java8新引入的函数式接口就是基于这个思想进行设计的。
2. 函数式接口定义
2.1 自定义如下
需要FunctionalInterface关键字显示声明:
@FunctionalInterface public interface AppleInterface { public void test(); }
2.2 系统预定义
java.util.function.Consumer; java.util.function.Function; java.util.function.Predicate; java.util.function.Supplier;
可以去查看源码了解具体的细节,这几个接口包括了常用的一些场景,一般可满足需要
3. 函数式接口的使用
函数式接口一般使用前需要先定义,也可以使用系统预定义的几个函数式接口
函数式接口的使用和使用一个变量没有区别,显示声明定义,格式如下:
FunctionInterface interface=null;
这里的interface虽然看起来是一个变量,可是实际却是一段行为代码,用于执行具体的业务逻辑,可以自由在方法接口间传递,也可以直接执行
interface.doSomeThing();
如定义函数式接口为参数的接口:
public void filter(FunctionInterface interface) { interface.doSomeThing(); }
4. 函数式接口练习
4.1 自定义实体类Apple
public class Apple { private String color; private float weight; public Apple(String color, float weight) { this.color = color; this.weight = weight; } public String getColor() { return color; } public void setColor(String color) { this.color = color; } public float getWeight() { return weight; } public void setWeight(float weight) { this.weight = weight; } }
4.2 自定义函数式接口
该接口有一个test方法,不接收任何参数,也没有任何返回
@FunctionalInterface public interface AppleInterface { public void test(); }
4.3 测试自定义函数式接口
@Test public void DefineFunctionInterface(){ //自定义函数式接口 AppleInterface at=()->System.out.println("define FunctionInterface AppleInterface."); at.test(); }
至此,就完成一个很简单的函数式接口的定义和调用
4.4 系统预定义函数式接口
Consumer<T>:该接口接收一个对象T,返回void,测试如下
@Test public void ConsumerTest(){ Consumer<Apple> consumer=(Apple app)->{System.out.println(app.getColor()+","+app.getWeight());}; List<Apple> apps=Arrays.asList(new Apple("red", 120),new Apple("blue", 80), new Apple("green",100)); ConsumerApple(apps,consumer); } public void ConsumerApple(List<Apple> apps,Consumer<Apple> c){ for(Apple app:apps){ c.accept(app); } }
Supplier<T>:该接口不接收任何参数,返回一个对象T,测试如下:
@Test public void SupplierTest(){ Supplier<Apple> supplier=()->{return new Apple("hello supplier",999);}; Apple app=supplier.get(); System.out.println(app.getColor()+","+app.getWeight()); }
Predicate<T>:该接口接收一个对象T,返回一个Boolean
@Test public void PredicateTest(){ //系统预定义函数式接口测试 Predicate<Apple> p1=(Apple a)->{if(a.getWeight()>90) return true;return false;}; Predicate<Apple> p2=(Apple a)->{if(a.getColor().equals("blue")) return true;return false;}; List<Apple> apps=Arrays.asList(new Apple("red", 120),new Apple("blue", 80), new Apple("green",100)); filterApple(apps,p1);//筛选重量大于90g的苹果 filterApple(apps,p2);//筛选蓝色的苹果 } public void filterApple(List<Apple> apps,Predicate<Apple> p){ for(Apple app:apps){ if(p.test(app)){ System.out.println(app.getColor()+","+app.getWeight()); } } }
Function<T,R>: 该接口接收一个对象T,经过转换判断,返回一个对象R
@Test public void FunctionTest(){ Function<String,Apple> function=(String s)->{return new Apple(s,666);}; Apple app=function.apply("red"); System.out.println(app.getColor()+","+app.getWeight()); app=function.apply("green"); System.out.println(app.getColor()+","+app.getWeight()); }
以上这篇基于Java8 函数式接口理解及测试就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。
主要内容:1 Java8 函数式接口的介绍,2 Java8 函数式接口的案例1,3 Java8 函数式接口的案例2,4 Java8 函数式接口的错误示范,5 Java8 函数式接口的案例3,6 Java8 预定义函数式接口1 Java8 函数式接口的介绍 完全包含一种抽象方法的接口称为函数式接口。函数式接口可以具有任意数量的默认静态方法,但只能包含一个抽象方法。函数式接口还可以声明对象类的方法。 函数式接口也称为单一抽象方法接口或SAM接口。它是Java8 中的新功能,有助于实现函数编程方法。
本文向大家介绍Java基于rest assured实现接口测试过程解析,包括了Java基于rest assured实现接口测试过程解析的使用技巧和注意事项,需要的朋友参考一下 背景 java程序员一般写的是后端服务是JavaWeb类型的项目,主要包括Http接口和dubbo接口,Http接口一般采用的rest风格,那么如何快速的对rest接口在第三方的测试框架上进行测试呢? rest-assure
本文向大家介绍Kotlin中的sam(函数式接口)详解,包括了Kotlin中的sam(函数式接口)详解的使用技巧和注意事项,需要的朋友参考一下 用lambda表达式去表示java中的匿名类实例 在使用java去给一个按钮设置监听我们通常会通过创建匿名类实例,如下 在kotlin我们可以通过传递一个lambda表达式去代替这个实例 可以以这种方式去实现的原因是OnClickListener接口只有一
为什么叫“函数式模型”,请查看“Keras新手指南”的相关部分 Keras的函数式模型为Model,即广义的拥有输入和输出的模型,我们使用Model来初始化一个函数式模型 from keras.models import Model from keras.layers import Input, Dense a = Input(shape=(32,)) b = Dense(32)(a) mode
既然我有一个带有两个方法的,那么我如何用一个具体的类实现它呢?如何为这两种方法编写Lambda表达式?
本文向大家介绍Kotlin 接口与 Java8 新特性接口详解,包括了Kotlin 接口与 Java8 新特性接口详解的使用技巧和注意事项,需要的朋友参考一下 前言 在看一本关于高性能编程的时候发现 Java8 中关于接口的新特性的介绍,这个特性是真的棒,解决了一个接口中有多个方法,但并不想实现该接口的类都去实现所有的方法,简单的说就是在类需要的情况再去重写接口。所以有了以下的特性出现。 接口增强