Scala 偏應(yīng)用函數(shù)
Scala 偏應(yīng)用函數(shù)
Scala 偏應(yīng)用函數(shù)是一種表達(dá)式,你不需要提供函數(shù)需要的所有參數(shù),只需要提供部分,或不提供所需參數(shù)。
如下范例,我們打印日志信息:
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) } }
執(zhí)行以上代碼,輸出結(jié)果為:
$ 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
范例中,log() 方法接收兩個(gè)參數(shù):date 和 message。我們?cè)诔绦驁?zhí)行時(shí)調(diào)用了三次,參數(shù) date 值都相同,message 不同。
我們可以使用偏應(yīng)用函數(shù)優(yōu)化以上方法,綁定第一個(gè) date 參數(shù),第二個(gè)參數(shù)使用下劃線(_)替換缺失的參數(shù)列表,并把這個(gè)新的函數(shù)值的索引的賦給變量。以上范例修改如下:
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) } }
執(zhí)行以上代碼,輸出結(jié)果為:
$ 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
相關(guān)文章
- JDBC 創(chuàng)建數(shù)據(jù)庫范例
- JDBC 創(chuàng)建、刪除表范例
- Hibernate ORM 概覽
- Hibernate 簡(jiǎn)介
- Hibernate 環(huán)境
- Hibernate 映射
- Hibernate 標(biāo)準(zhǔn)查詢
- Hibernate 緩存
- Maven 環(huán)境配置
- Maven 依賴管理
- Gson 教程
- Gson 第一個(gè)應(yīng)用
- Gson 流
- Gson 定制型適配器
- Scala 簡(jiǎn)介
- Scala 安裝
- Scala 數(shù)組
- Spring ORM框架
- Spring SPEL表達(dá)式
- Spring Java Mail