1.引言
最近接手了一個kotlin項目,遇到apply內(nèi)聯(lián)函數(shù),于是花點(diǎn)時間瞅了瞅凸舵。發(fā)現(xiàn)還有點(diǎn)意思。于是花點(diǎn)時間整理整理失尖。
2.正題
2.1 run 函數(shù)
@kotlin.internal.InlineOnly
public inline fun <T, R> T.run(block: T.() -> R): R {
contract {
callsInPlace(block, InvocationKind.EXACTLY_ONCE)
}
return block()
}
傳入的是一個T的拓展對象啊奄。返回一個泛型R。R類型可以是一個函數(shù)雹仿,一個變量增热,一個類的實(shí)例
例如:
val resultRun = test.run {
name = "xys"
age = 3
println("Run內(nèi)部 $this")
age
}
2.2 let函數(shù)
@kotlin.internal.InlineOnly
public inline fun <T, R> T.let(block: (T) -> R): R {
contract {
callsInPlace(block, InvocationKind.EXACTLY_ONCE)
}
return block(this)
}
傳入一個方法,參數(shù)為T胧辽,返回一個泛型R峻仇。let函數(shù) 和run的函數(shù) 都會返回一個泛型R。主要的區(qū)別在于參數(shù)邑商。一個參數(shù)是T.() 一個參數(shù)是(T) 摄咆。根據(jù)面向?qū)ο笏季S。當(dāng)方法體是對那個對象進(jìn)行拓展人断,我們采用run函數(shù)吭从;當(dāng)方法體是業(yè)務(wù)邏輯,對象僅僅只是一個參數(shù)作用的時候恶迈,我們就選用let
2.3 apply函數(shù)
@kotlin.internal.InlineOnly
public inline fun <T> T.apply(block: T.() -> Unit): T {
contract {
callsInPlace(block, InvocationKind.EXACTLY_ONCE)
}
block()
return this
}
傳入一個拓展函數(shù)涩金,返回值為對象本身this。
例子:
var s2=s.apply {
s.address = "深圳"
s.age = 100
}
2.4 also函數(shù)
@kotlin.internal.InlineOnly
@SinceKotlin("1.1")
public inline fun <T> T.also(block: (T) -> Unit): T {
contract {
callsInPlace(block, InvocationKind.EXACTLY_ONCE)
}
block(this)
return this
}
also 函數(shù) 和apply函數(shù)的區(qū)別暇仲,在于 also函數(shù)的參數(shù)是(T)步做。apply參數(shù)是T.()。奈附。例如類B的一個方法 要使用類A對象全度。我們此刻只能是B.aslo(A)〕饴耍可以看出also 更加適用于對對象的操作将鸵。apply適用于單對象的操作。
2.5 with 函數(shù)
@kotlin.internal.InlineOnly
public inline fun <T, R> with(receiver: T, block: T.() -> R): R {
contract {
callsInPlace(block, InvocationKind.EXACTLY_ONCE)
}
return receiver.block()
}
with函數(shù) 前面沒有T. 意味著 不能被對象直接調(diào)用佑颇。需要將調(diào)用的對象T顶掉,作為receiver參數(shù)。外加一個T的拓展函數(shù)挑胸。最后返回一個泛型R一喘。這個泛型可以是函數(shù),可以是基本變量