本篇文章為大家展示了kotlin Standard中的內聯(lián)函數(shù),內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
創(chuàng)新互聯(lián)網(wǎng)站建設公司,提供網(wǎng)站建設、網(wǎng)站設計,網(wǎng)頁設計,建網(wǎng)站,PHP網(wǎng)站建設等專業(yè)做網(wǎng)站服務;可快速的進行網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,是專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!
let、with、run、apply、also、takeIf、takeUnless、repeat函數(shù)的使用
kotlin Standard.kt文件中,提供了一些內聯(lián)函數(shù),這些內聯(lián)函數(shù)可以減少代碼量,在使代碼優(yōu)美的同時,打打提高開發(fā)效率。它們分別為:
run、with、let、also、apply
let
let函數(shù)的定義如下:
public inline funT.let(block: (T) -> R): R = block(this)
默認當前這個對象作為閉包的it參數(shù),函數(shù)接受一個lambda函數(shù)塊返回值是函數(shù)里面最后一行,或者指定return
let函數(shù)的一般結構為:
obj.let { it.todo//it指代obj對象實例 ... } //在需要判斷obj是否為null時 obj?.let { it.todo//it指代obj對象實例 ... }
使用實例:初始化user
val user = User() val result= user.let { it.account = "12306" it.address = "粵海街道" it.address } println(result) //運行結果 >>粵海街道
適用場景:
用let函數(shù)處理需要針對一個可null的對象統(tǒng)一做判空處理
明確一個變量所在特定作用域的范圍
with
with函數(shù)的定義如下:
public inline funwith(receiver: T, block: T.() -> R): R = receiver.block()
with函數(shù)不是以擴展函數(shù)的形式存在,它是將對象作為參數(shù),在函數(shù)塊內通過this指代該對象。with函數(shù)是接收了兩個參數(shù),分別為對象receiver和一個lambda函數(shù)塊,返回值為函數(shù)塊的最后一行或指定return表達式。
with的一般結構為:
with(obj){ this.todo todo//this可省略 ... }
使用實例:將地址影射到UI上
with(user){ tView.text = address }
適用范圍:
適用于調用一個類的多個方法,可以省去對象名直接調用方法(例如將數(shù)據(jù)影射到ui上時)
run
run函數(shù)的定義如下:
public inline funT.run(block: T.() -> R): R = block()
run函數(shù)接受一個lambda函數(shù)塊,以閉包的形式返回函數(shù)塊的最后一行或指定return表達式。觀察函數(shù)的定義可以發(fā)現(xiàn),run函數(shù)為一個擴展函數(shù),而其接受的參數(shù)和with函數(shù)第二個參數(shù)相同,run函數(shù)可以理解為let函數(shù)和with函數(shù)的結合體。
run函數(shù)的一般結構為:
obj.run { this.todo todo//this可省略 ... }
使用實例:將地址影射到UI上
user.run { tView.text = address }
適用范圍:
適用于let和run函數(shù)的場景,run函數(shù)相較于let函數(shù)省去了必須適用it指代參數(shù)的麻煩,相較于with函數(shù)彌補了對象判空的問題
also
also函數(shù)的定義如下:
public inline funT.also(block: (T) -> Unit): T { block(this); return this }
also函數(shù)的定義和let函數(shù)的類似,只是also函數(shù)返回的為傳入對象的本身。
also函數(shù)的一般結構和使用方法和let函數(shù)類似:
obj.also { it.todo//it指代obj對象實例 ... } //在需要判斷obj是否為null時 obj?.let { it.todo//it指代obj對象實例 ... }
適用范圍:
also函數(shù)返回值微傳入方法的對象本身,所以可用來進行函數(shù)的鏈式調用
apply
apply函數(shù)的定義如下:
public inline funT.apply(block: T.() -> Unit): T { block(); return this }
apply函數(shù)的定義和run函數(shù)的類似,唯一的區(qū)別就是apply函數(shù)返回的為傳入對象的本身。
apply函數(shù)一般結構如下:
apply函數(shù)一般結構如下: obj.apply { this.todo todo//this可省略 ... }
使用實例:給對象賦值
var user = User().apply { account = "12306" }
適用場景:
apply函數(shù)和run函數(shù)除了返回值外,整體功能和作用類似,一般用于對象初始化時對屬性進行賦值。
總結:
這里我們總結對比一下這五個函數(shù),這五個函數(shù)的特性非常簡單,區(qū)別也無非是接受的參數(shù)和返回的類型不同。其中,對于with,run,apply接收者是this(可以省略),而let和also則使用it接受且不可s省略對于;
對于with,run,let返回值是返回值是函數(shù)里面最后一行,或者指定return,而apply和also返回值是調用者本身。
函數(shù)名 | 接受者 | 返回值 |
---|---|---|
let | it | 最后一行 |
with | this | 最后一行 |
run | this | 最后一行 |
also | it | 調用者本身 |
apply | this | 調用者本身 |
如何選擇可以參考下圖
takeIf、takeUnless、repeat
takeIf & takeUnless
takeIf函數(shù)的定義如下:
public inline funT.takeIf(predicate: (T) -> Boolean): T? = if (predicate(this)) this else null
可以看出:takeIf函數(shù)接受一個入?yún)㈩愋蜑檎{用者的類型T,返回值為Boolean類型的lambda函數(shù)塊。takeIf函數(shù)根據(jù)lambda函數(shù)返回值返回的數(shù)據(jù),為true返回調用者本身,否則返回null
takeUnless函數(shù)的定義如下:
public inline funT.takeUnless(predicate: (T) -> Boolean): T? = if (!predicate(this)) this else null
不難看出,takeUnless相對比takeIf只是在返回值調用predicate(this)進行了取反操作,takeUnless的作用效果和takeIf正好相反!
takeIf函數(shù)一般結構如下:
obj.takeIf{ ... true/fals }
使用實例:
//根據(jù)age為user賦值,若age在1-100之間,為user.age賦值age,否則user.age為null var age ... user.age = age.takeIf { age in 1..99 }.toString() user.age = age.ta { age in 100..0 }.toString()
repeat
repeat函數(shù)的定義如下:
public inline fun repeat(times: Int, action: (Int) -> Unit) { for (index in 0 until times) { action(index) } }
函數(shù)接受一個int類型數(shù)據(jù)times,和一個入?yún)閕nt類型,無返回值的lambda函數(shù)action,并通過for循環(huán)重復的調用times次action函數(shù)
函數(shù)的一般結構如下:
repeat(int){ todo }
使用實例:
//快速的為list添加十條數(shù)據(jù) var list = ArrayList() repeat(10){ list.add(User()) }
上述內容就是kotlin Standard中的內聯(lián)函數(shù),你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。