Kotlin示例講解標準函數(shù)with與run和apply的使用
1.with 函數(shù)
首先先從with函數(shù)開始,with函數(shù)接受兩個參數(shù),第一個參數(shù)可以是一個任意類型的對象,第二個參數(shù)是一個Lambda表達式。with函數(shù)會在Lambda表達式中提供第一個參數(shù)對象的上下文,并且使用Lambda表達式中的最后一行代碼作為返回值進行返回,代碼如下:
val with = with(obj) {
//這里是 obj 的上下文
"value" //with 函數(shù)的返回值
}那么這個函數(shù)有什么用的? 它可以在連續(xù)同一個對象的多個方法時讓代碼變得精簡,下面描述一個具體的例子:
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對象的方法。其實這個時候就可以考慮使用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類似,只是稍微做了一些語法的改動。首先run函數(shù)通常不會直接調(diào)用,而是要在某個對象的基礎(chǔ)上調(diào)用;其實run函數(shù)只接受一個Lambda參數(shù),并且在Lambda表達式中提供調(diào)用對象的上下文。其它方面和with一樣,包括也會使用Lambda表達式中的最后一行代碼作為返回值返回。示例如下:
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ù)也是及其類似,都是要在某個對象上調(diào)用,并且只接受一個Lambda參數(shù),也會在Lambda表達式中提供對象的上下文,但是apply函數(shù)無法定義返回值,而是會自動返回調(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實際上是一個StringBuffer對象,所以在最后打印的時候還要再調(diào)用它的toSting()方法才行。
到此這篇關(guān)于Kotlin示例講解標準函數(shù)with與run和apply的使用的文章就介紹到這了,更多相關(guān)Kotlin with run apply內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android 添加系統(tǒng)設(shè)置屬性的實現(xiàn)及步驟
這篇文章主要介紹了Android 添加系統(tǒng)設(shè)置屬性的實現(xiàn)及步驟的相關(guān)資料,需要的朋友可以參考下2017-07-07
Android App調(diào)試內(nèi)存泄露之Cursor篇
最近在工作中處理了一些內(nèi)存泄露的問題,在這個過程中我尤其發(fā)現(xiàn)了一些基本的問題反而忽略導(dǎo)致內(nèi)存泄露2012-11-11

