欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Kotlin示例講解標(biāo)準(zhǔn)函數(shù)with與run和apply的使用

 更新時(shí)間:2022年08月02日 15:01:11   作者:m0_63970488  
Kotlin的標(biāo)準(zhǔn)函數(shù)是指 Standard.kt 文件中定義的函數(shù),任何Kotlin代碼都可以自由地調(diào)用所有的標(biāo)準(zhǔn)函數(shù)。文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧

1.with 函數(shù)

首先先從with函數(shù)開(kāi)始,with函數(shù)接受兩個(gè)參數(shù),第一個(gè)參數(shù)可以是一個(gè)任意類(lèi)型的對(duì)象,第二個(gè)參數(shù)是一個(gè)Lambda表達(dá)式。with函數(shù)會(huì)在Lambda表達(dá)式中提供第一個(gè)參數(shù)對(duì)象的上下文,并且使用Lambda表達(dá)式中的最后一行代碼作為返回值進(jìn)行返回,代碼如下:

        val with = with(obj) {
            //這里是 obj 的上下文
            "value" //with 函數(shù)的返回值
        }

那么這個(gè)函數(shù)有什么用的? 它可以在連續(xù)同一個(gè)對(duì)象的多個(gè)方法時(shí)讓代碼變得精簡(jiǎn),下面描述一個(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對(duì)象的方法。其實(shí)這個(gè)時(shí)候就可以考慮使用with函數(shù)來(lái)讓代碼變得精簡(jiǎn):

        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ù)的用法和使用場(chǎng)景和上面with類(lèi)似,只是稍微做了一些語(yǔ)法的改動(dòng)。首先run函數(shù)通常不會(huì)直接調(diào)用,而是要在某個(gè)對(duì)象的基礎(chǔ)上調(diào)用;其實(shí)run函數(shù)只接受一個(gè)Lambda參數(shù),并且在Lambda表達(dá)式中提供調(diào)用對(duì)象的上下文。其它方面和with一樣,包括也會(huì)使用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")

總體來(lái)說(shuō),變化非常小,只是將with函數(shù)并傳入StringBuffer對(duì)象改成了StringBuffer對(duì)象的run方法,其它沒(méi)有任何區(qū)別,這兩段代碼執(zhí)行的結(jié)果也是一樣的。

3.apply函數(shù)

apply函數(shù)和run函數(shù)也是及其類(lèi)似,都是要在某個(gè)對(duì)象上調(diào)用,并且只接受一個(gè)Lambda參數(shù),也會(huì)在Lambda表達(dá)式中提供對(duì)象的上下文,但是apply函數(shù)無(wú)法定義返回值,而是會(huì)自動(dòng)返回調(diào)用對(duì)象本身,示例代碼如下:

        val result = obj.apply {
            //這里是obj的上下文
        }
        //result == obj

現(xiàn)在我們?cè)偈褂胊pply函數(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ù)無(wú)法定義返回值,只能返回調(diào)用對(duì)象本身,因此這里result實(shí)際上是一個(gè)StringBuffer對(duì)象,所以在最后打印的時(shí)候還要再調(diào)用它的toSting()方法才行。

到此這篇關(guān)于Kotlin示例講解標(biāo)準(zhǔn)函數(shù)with與run和apply的使用的文章就介紹到這了,更多相關(guān)Kotlin with run apply內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論