博客
关于我
Java 8 中的 Lambda 表达式 vs. Kotlin 中的 Lambda
阅读量:290 次
发布时间:2019-03-01

本文共 2564 字,大约阅读时间需要 8 分钟。

Kotlin 函数式编程实例与高阶函数

代码示例

package com.easykotlin.lec02funfun sum1(x: Int, y: Int): Int {    return x + y}fun sum2(x: Int, y: Int) = x + y// sum2 函数字面量:匿名函数val sum3 = fun(x: Int, y: Int) = x + yval s3 = (fun(x: Int, y: Int) = x + y)(1, 1)val s32 = (fun(x: Int, y: Int) = x + y).invoke(1, 1)// Lambdaval sum4 = { x: Int, y: Int -> x + y }val s4 = { x: Int, y: Int -> x + y }(1, 1)val s42 = { x: Int, y: Int -> x + y }.invoke(1, 1)val sum5: (Int, Int) -> Int = { x, y -> x + y }// 高阶函数fun repeat(n: Int, body: () -> Unit) {    for (i in 1..n) {        body()    }}// 类型别名typealias A = (String) -> Inttypealias B = (Int) -> Booleantypealias C = (String) -> Booleanval length: A = { x -> x.length }val isOdd: B = { x -> x % 2 == 1 }// 高阶函数(复合函数)val filterOdd: C = { x -> isOdd(length(x)) }fun main(args: Array
) { val list = listOf("a", "abc", "abcbdf", "adsfeeff", "qwedddsssssdd") // 过滤出 list 中字符串长度是奇数的元素 val result = list.filter(filterOdd) println(result) repeat(3) { println("A") } // 1 + 2 + ... + 100 var sum = 0 var i = 1 repeat(100) { sum += i i++ } println("sum = $sum") sum1(1, 1) sum2(1, 1) sum3(1, 1) sum4(1, 1) sum5(1, 1) println("s3 = $s3") println("s32 = $s32") println("s4 = $s4") println("s42 = $s42")}

Java 8 对比

public void filter(Filter f, List
integerList) { for (Integer i : integerList) { if (f.test(i)) { System.out.println(i); } }}// 定义一个 SAMinterface Filter { boolean test(int x);}public void lambdaDemo() { filter((x) -> x % 2 == 1, Arrays.asList(1, 2, 3, 4, 5, 6, 7));}

Kotlin 优势

在 Kotlin 中,函数 f: (Int) -> Boolean 也是一种类型,可以像普通的参数变量一样,在函数入参中传递,当然也可以返回一个函数。

高阶函数示例

fun repeat(times: Int, body: () -> Unit) {    for (i in 0 until times) {        body()    }}fun main(args: Array
) { repeat(3, { println("A") }) repeat(3) { println("B") } var sum = 0 var i = 1 repeat(100) { sum += i i++ } println(sum)}

Function 接口

Function 接口类型只有一个调用方法:invoke()。

它包含三个动作:传入参数、处理参数、返回结果。

Kotlin 定义了 kotlin.jvm.functions 包里的接口,用于抽象所有函数类型。这些接口包括:

  • Function0:没有参数
  • Function1:有一个参数
  • Function2:有两个参数
  • ...
  • FunctionN:支持 23 个及以上参数

每个接口都继承自 Function,并定义了 invoke() 方法,通过重载括号操作符来传入参数和获取返回值。

匿名函数与 Lambda

val sum: (Int, Int) -> Int = fun(a: Int, b: Int) = a + b// 或者省略类型声明val sum = fun(a: Int, b: Int) = a + b// Lambda 表达式val sum = { a: Int, b: Int -> a + b }

这些函数对象会被编译为 Function2 类型的实现,可以通过 invoke() 方法调用,也可以直接使用括号操作符:

println(sum.invoke(1, 2))// 或者println(sum(1, 2))

小结

相比之下,Kotlin 对函数式编程的支持更加自然优雅。

转载地址:http://biea.baihongyu.com/

你可能感兴趣的文章
Nginx配置如何一键生成
查看>>
Nginx配置实例-负载均衡实例:平均访问多台服务器
查看>>
Nginx配置文件nginx.conf中文详解(总结)
查看>>
Nginx配置负载均衡到后台网关集群
查看>>
ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
查看>>
NHibernate学习[1]
查看>>
NHibernate异常:No persister for的解决办法
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>