Kotlin示例講解標(biāo)準(zhǔn)函數(shù)with與run和apply的使用
1.with 函數(shù)
首先先從with函數(shù)開始,with函數(shù)接受兩個(gè)參數(shù),第一個(gè)參數(shù)可以是一個(gè)任意類型的對象,第二個(gè)參數(shù)是一個(gè)Lambda表達(dá)式。with函數(shù)會在Lambda表達(dá)式中提供第一個(gè)參數(shù)對象的上下文,并且使用Lambda表達(dá)式中的最后一行代碼作為返回值進(jìn)行返回,代碼如下:
val with = with(obj) { //這里是 obj 的上下文 "value" //with 函數(shù)的返回值 }
那么這個(gè)函數(shù)有什么用的? 它可以在連續(xù)同一個(gè)對象的多個(gè)方法時(shí)讓代碼變得精簡,下面描述一個(gè)具體的例子:
val listOf = listOf<String>("Apple", "Banana", "Orange", "Pear", "Grape") val obj = StringBuffer() obj.append("Start eating fruits.\n") for (s in listOf) { obj.append(s).append("\n") } obj.append("Ate all fruits.") val result = obj.toString() println(result)
這樣我們連續(xù)調(diào)用了很多次obj對象的方法。其實(shí)這個(gè)時(shí)候就可以考慮使用with函數(shù)來讓代碼變得精簡:
val listOf = listOf<String>("Apple", "Banana", "Orange", "Pear", "Grape") val result = with(StringBuffer()) { append("Start eating fruits.\n") for (s in listOf) { append(s).append("\n") } append("Ate all fruits.") toString() } Log.d("TAG", "initData: $result")
2.run函數(shù)
run函數(shù)的用法和使用場景和上面with類似,只是稍微做了一些語法的改動(dòng)。首先run函數(shù)通常不會直接調(diào)用,而是要在某個(gè)對象的基礎(chǔ)上調(diào)用;其實(shí)run函數(shù)只接受一個(gè)Lambda參數(shù),并且在Lambda表達(dá)式中提供調(diào)用對象的上下文。其它方面和with一樣,包括也會使用Lambda表達(dá)式中的最后一行代碼作為返回值返回。示例如下:
val result = obj.run { //這里是obj的上下文 "value" //run函數(shù)的返回值 }
val listOf = listOf<String>("Apple", "Banana", "Orange", "Pear", "Grape") val result = StringBuffer().run { append("Start eating fruits.\n") for (s in listOf) { append(s).append("\n") } append("Ate all fruits.") toString() } Log.d("TAG", "initData: $result")
總體來說,變化非常小,只是將with函數(shù)并傳入StringBuffer對象改成了StringBuffer對象的run方法,其它沒有任何區(qū)別,這兩段代碼執(zhí)行的結(jié)果也是一樣的。
3.apply函數(shù)
apply函數(shù)和run函數(shù)也是及其類似,都是要在某個(gè)對象上調(diào)用,并且只接受一個(gè)Lambda參數(shù),也會在Lambda表達(dá)式中提供對象的上下文,但是apply函數(shù)無法定義返回值,而是會自動(dòng)返回調(diào)用對象本身,示例代碼如下:
val result = obj.apply { //這里是obj的上下文 } //result == obj
現(xiàn)在我們再使用apply函數(shù)修改一下吃水果這段代碼 , 如下:
val listOf = listOf<String>("Apple", "Banana", "Orange", "Pear", "Grape") val result = StringBuffer().apply { append("Start eating fruits.\n") for (s in listOf) { append(s).append("\n") } append("Ate all fruits.") } Log.d("TAG", "initData: ${result.toString()}")
由于apply函數(shù)無法定義返回值,只能返回調(diào)用對象本身,因此這里result實(shí)際上是一個(gè)StringBuffer對象,所以在最后打印的時(shí)候還要再調(diào)用它的toSting()方法才行。
到此這篇關(guān)于Kotlin示例講解標(biāo)準(zhǔn)函數(shù)with與run和apply的使用的文章就介紹到這了,更多相關(guān)Kotlin with run apply內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android之ImageSwitcher的實(shí)例詳解
這篇文章主要介紹了Android之ImageSwitcher的實(shí)例詳解的相關(guān)資料,這里提供實(shí)例幫助大家理解這個(gè)控件的功能,希望能幫助到大家,需要的朋友可以參考下2017-08-08Android上傳文件到服務(wù)端并顯示進(jìn)度條
這篇文章主要為大家詳細(xì)介紹了Android上傳文件到服務(wù)端,并顯示進(jìn)度條,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11Android填坑系列:在小米系列等機(jī)型上放開定位權(quán)限后的定位請求彈框示例
本文詳細(xì)介紹了在小米系列等機(jī)型上放開定位權(quán)限后的定位請求彈框示例,例如在應(yīng)用軟件中提示顯示定位服務(wù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2016-11-11Android編程實(shí)現(xiàn)拍照功能的2種方法分析
這篇文章主要介紹了Android編程實(shí)現(xiàn)拍照功能的2種方法,結(jié)合具體實(shí)例形式對比分析了Android通過調(diào)用系統(tǒng)攝像頭及程序調(diào)用照相機(jī)功能兩種實(shí)現(xiàn)技巧與相關(guān)注意事項(xiàng),需要的朋友可以參考下2017-07-07Flutter使用RepositoryProvider解決跨組件傳值問題
在實(shí)際開發(fā)過程中,經(jīng)常會遇到父子組件傳值的情況。本文將利用RepositoryProvider解決跨組件傳值的問題,感興趣的小伙伴可以了解一下2022-04-04Android NDK生成及連接靜態(tài)庫與動(dòng)態(tài)庫的方法
這篇文章主要介紹了Android NDK生成及連接靜態(tài)庫與動(dòng)態(tài)庫的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-08-08Android應(yīng)用中使用ContentProvider掃描本地圖片并顯示
這篇文章主要介紹了Android應(yīng)用中使用ContentProvider掃描本地圖片并顯示的方法,比調(diào)用本地圖庫的方法更加靈活和可定制,需要的朋友可以參考下2016-04-04