【Java8】Guava——Function
来源:互联网 发布:windows系统购买 编辑:程序博客网 时间:2024/06/11 11:58
函数式编程
函数式编程是一种历久弥新的编程范式,比起命令式编程,它更加关注程序的执行结果而不是执行过程。
Java 始终是一个面向对象(命令式)的语言,在我们使用函数式编程这种黑魔法之前,需要确认:同样的功能,使用函数式编程来实现,能否在健壮性和可维护性上,超过使用面向对象(命令式)编程的实现?
Function
实例化这个仿函数接口要求至少要实现 apply 方法。只有在需要判断两个函数是否等价的时候才覆盖实现 equals 方法
Guava
Java8
@FunctionalInterfacepublic interface Function<T, R>{ R apply(T t); default <V> Function<V, R> compose(Function<? super V, ? extends T> before) { Objects.requireNonNull(before); return (V v) -> apply(before.apply(v)); } 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<Double, Double> sqrt = new Function<Double, Double>() { public Double apply(Double input) { return Math.sqrt(input); }};sqrt.apply(4.0);//2.0
这里我们通过实例化一个匿名类的方式来完成了仿函数的定义、初始化和赋值。
注意到仿函数始终不是一个函数,而是一个对象,我们只能调用这个对象的方法来模拟函数调用。
这种 Function 接口的用法和函数式编程中将一个匿名函数赋值给变量的做法类似。当然,更加常见的函数定义方式是显式的声明一个函数然后实现它。
class SqrtFunction implements Function<Double, Double> { public Double apply(Double input) { return Math.sqrt(input); }}new SqrtFunction().apply(4.0);//2.0
仅接收两个参数的函数
Function<SimpleEntry<Double, Double>, Double> power = new Function<SimpleEntry<Double, Double>, Double>() { public Double apply(SimpleEntry<Double, Double> input) { return Math.pow(input.getKey(), input.getValue()); }};power.apply(new SimpleEntry<Double, Double>(3.0, 2.0));//9.0
接收可变参数的函数
由于变长参数实际上是 Java 编译器提供的语法糖,在编译期间会被解语法糖变成对象数组 Object[],而且变长参数无法作为泛型参数,这里直接使用对象数组作为参数
Function<Double[], Double> sum = new Function<Double[], Double>() { public Double apply(Double[] input) { Double result = 0.0; for (Double element : input) { result += element; } return result; }};sum.apply(new Double[]{3.0, 4.0, 5.1});//12.1
Functions
- toStringFunction() : f(x)=x.toString()f(x)=x.toString()
- identity():f(x)=x
- constanct() : f(x)=a
- compose() : 返回一个复合函数 h(x)=g(f(x))h(x)=g(f(x)),以两个函数为入参,返回这两个函数复合之后的函数。例如我们有函数 f:X→Yf:X→Y 和函数 g:Y→Zg:Y→Z,复合之后得到复合函数 g∘f:X→Z
forMap(java.util.Map<K,V>) //f(x)=map.get(x)forMap(java.util.Map<K,? extends V>, V) //区别在于这个方法的第二个参数是一个默认值,当映射中不包含入参键的时候,第一个方法返回的函数会抛出异常,而第二个方法返回的函数会返回默认值forPredicate() //以 Guava 的谓词实例为入参 返回一个 Function 实例forSupplier() //以 Guava 的 Supplier 实例为入参,返回一个 Function 实例
Function更多参考
1 0
- 【Java8】Guava——Function
- 【Java8】Guava——Optional
- 【Java8】Guava——Joiner
- 【Java8】Guava——Splitter
- 【Java8】Guava——Charsets
- 【Java8】Guava——Preconditions
- 【Java8】Guava——Predicate
- 【Java8】Guava——Object方法和排序
- guava Function
- Guava Function类简介
- guava Function Predicate Supplier
- guava Function Predicate Supplier
- Guava functional -- Function
- guava学习之——guava简介
- [Guava]——MultiMap
- [Guava]——BiMap
- Guava —— Optional
- Guava — Preconditions
- velocity基础教程--2自定义ResourceLoader实现字符模板
- 图论—深度优先和广度优先算法源码
- PAT乙级(Basic Level)真题 >到底买不买
- vi 操作指南
- redis中密码设置
- 【Java8】Guava——Function
- Eclipse中安装Velocity插件
- js倒计时(天,时,分,秒),适用于web和移动端
- velocity中宏的配置
- Linux系统之lspci命令介绍
- hibernate 一级缓存、二级缓存
- java学习笔记9——异常处理
- 《JavaScript 高级程序设计》书摘----变量、作用域和内存
- velocity文档