Kotlin將函式作為引數傳遞,使用雙冒號::引用其他方法
阿新 • • 發佈:2018-11-22
Kotlin 中 雙冒號操作符 表示把一個方法當做一個引數,傳遞到另一個方法中進行使用,通俗的來講就是引用一個方法。先來看一下例子:
fun main(args: Array<String>) { println(lock("param1", "param2", ::getResult)) } /** * @param str1 引數1 * @param str2 引數2 */ fun getResult(str1: String, str2: String): String = "result is {$str1 , $str2}" /** * @param p1 引數1 * @param p2 引數2 * @param method 方法名稱 */ fun lock(p1: String, p2: String, method: (str1: String, str2: String) -> String): String { return method(p1, p2) }
這裡需要注意的是,lock 函式 的第三個引數傳入 method 時,要確定引數個數、型別、返回值都和其形參一致。
輸出結果:
result is {param1 , param2}
如果我們需要呼叫其他 Class 中的某一個方法是:
寫法為:
fun main(args: Array<String>) {
var d = Test()
println(lock("param1", "param2", d::getResult))
}
我們在 Class 中的某個方法中使用雙冒號呼叫當前 Class 的內部方法時調動方式為:
class Test1 {
fun isOdd(x: Int) = x % 2 != 0
fun test() {
var list = listOf(1, 2, 3, 4, 5)
println(list.filter(this::isOdd))
}
}
一般情況,我們呼叫當前類的方法 this 都是可省略的,這裡之所以不可省略的原因是
為了防止作用域混淆 , :: 呼叫的函式如果是類的成員函式或者是擴充套件函式,必須使用限定符,比如this
如果把 isOdd 寫到 class 外部 (全域性) 這裡也是可以省略限定符。