小白教程
所有教程
关于
Search
172.70.100.206
172.70.100.206
参数设置
贡献
退出
操作
编辑
移动
保护
信息
历史
删除
查看“Partially applied functions”的源代码
本页内容
上一节:
Anonymous_functions
下一节:
Currying_functions
因为以下原因,您没有权限编辑本页:
您请求的操作仅限属于该用户组的用户执行:
用户
您可以查看和复制此页面的源代码。
{{DISPLAYTITLE:偏应用函数}}[[Category:scala functions|9]] = Scala 偏应用函数 = [[scala functions|Scala 函数]] Scala 偏应用函数是一种表达式,你不需要提供函数需要的所有参数,只需要提供部分,或不提供所需参数。 如下实例,我们打印日志信息: <pre> import java.util.Date object Test { def main(args: Array[String]) { val date = new Date log(date, "message1" ) Thread.sleep(1000) log(date, "message2" ) Thread.sleep(1000) log(date, "message3" ) } def log(date: Date, message: String) = { println(date + "----" + message) } } </pre> 执行以上代码,输出结果为: <pre> $ scalac Test.scala $ scala Test Mon Dec 02 12:52:41 CST 2018----message1 Mon Dec 02 12:52:41 CST 2018----message2 Mon Dec 02 12:52:41 CST 2018----message3 </pre> 实例中,log() 方法接收两个参数:date 和 message。我们在程序执行时调用了三次,参数 date 值都相同,message 不同。 我们可以使用偏应用函数优化以上方法,绑定第一个 date 参数,第二个参数使用下划线(_)替换缺失的参数列表,并把这个新的函数值的索引的赋给变量。以上实例修改如下: <pre> import java.util.Date object Test { def main(args: Array[String]) { val date = new Date val logWithDateBound = log(date, _ : String) logWithDateBound("message1" ) Thread.sleep(1000) logWithDateBound("message2" ) Thread.sleep(1000) logWithDateBound("message3" ) } def log(date: Date, message: String) = { println(date + "----" + message) } } </pre> 执行以上代码,输出结果为: <pre> $ scalac Test.scala $ scala Test Tue Dec 18 11:25:54 CST 2018----message1 Tue Dec 18 11:25:54 CST 2018----message2 Tue Dec 18 11:25:54 CST 2018----message3 </pre> [[scala functions|Scala 函数]]
返回至“
Partially applied functions
”。
上一节:
Anonymous_functions
下一节:
Currying_functions