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

Kotlin標準庫函數(shù)使用分析及介紹

 更新時間:2022年09月06日 10:29:33   作者:niuyongzhi  
Kotlin提供了一個系統(tǒng)庫,是Java庫的增強。其中有很多函數(shù)在適配了Java的類型和方法同時使用Kotlin的語法。其中一些底層的函數(shù) 是使用比較廣泛的

1.apply 函數(shù)

apply函數(shù)可以看做是一個配置函數(shù)。針對apply函數(shù)的調用者做一些配置,并把調用者返回。

示例:下面apply的調用者是file,調用完之后,返回的還是file,并在apply函數(shù)中,針對file做了一些配置。

    val file = File("d:\\hello.txt").apply {
        setWritable(true)
        setReadable(true)
        setExecutable(false)
    }

apply源碼分析:

1)apply 用inline修飾,是一個內聯(lián)函數(shù)。

2)定義了一個<T>泛型,T.apply 調用者就是T,:T apply返回的類型也是T

上面的file就相當于T

3)再看apply的參數(shù):block: T.() -> Unit。這是一個匿名函數(shù),T.()->說明接收的是T的函數(shù)返回的是Unit類型。

4)在apply內部 調用了這個匿名函數(shù)block()也就是T的

5)return this,就是apply 的返回值,返回的是當前調用apply函數(shù)的對象。

public inline fun <T> T.apply(block: T.() -> Unit): T {
    block()
    return this
}

2.let 函數(shù)

let函數(shù)會把調用者作為參數(shù)傳到lambda表達式里,可以用it來代替它使用。函數(shù)執(zhí)行完畢,lambda表達式返回的結果,就是let函數(shù)返回的結果。

    val hello = "Hello world".let {
        it.replace("world","kotlin")
    }
    //打印結果 Hello kotlin
    println(hello)

看下let函數(shù)的定義:

1)let函數(shù)也是一個內聯(lián)函數(shù)。

2)定義了兩個泛型<T,R> T.let(),說明T是let的調用者。

3)block: (T) -> R 說明let接收的是一個匿名函數(shù),匿名函數(shù)的參數(shù)是T,返回值是R

4): R 說明let函數(shù)的返回在也是R,也就是定義的匿名函數(shù)的返回值。

5)return block(this) 把當前調用者當做參數(shù)傳進來,lambda執(zhí)行結果返回

上面的示例,調用let后,會把調用者當做參數(shù)傳遞到匿名函數(shù)也就是lambda中,并把lambda的執(zhí)行結果,當做是let的結果返回。

inline fun <T, R> T.let(block: (T) -> R): R {
    return block(this)
}

3.run函數(shù)

run函數(shù)和apply差不多,可以給調用者做配置。唯一的差別是apply返回的是當前調用者對象,而run返回的是lambda執(zhí)行的結果。

    val text = File("d:\\hello.txt").run {
        setWritable(true)
        setReadable(true)
        setExecutable(false)
        readText()
    }
    println(text)

run函數(shù)分析:

1)run函數(shù)也是一個內聯(lián)函數(shù)。

2)有兩個泛型<T,R>,T是當前調用者,R是返回值

3)run接收一個lambda :block: T.() -> R 調用T的方法,并且把執(zhí)行結果返回

4): R lambda的執(zhí)行結果,就是run函數(shù)的執(zhí)行結果。我們知道lambda默認會把最后一行的結果返回。

5)return block() 返回lambda的執(zhí)行結果

inline fun <T, R> T.run(block: T.() -> R): R {
    return block()
}

4.with 函數(shù)

with函數(shù)是run的變體,他們的功能是一樣的。唯一的不同是調用方式,調用with時,第一個參數(shù)需要傳入一個值參。

    val hello = "Hello World"
    val h2 = with(hello) {
        replace("World", "Kotlin")
    }
    println(h2)

源碼分析:

with接收兩個參數(shù),第一個是傳入的值參,第二個是一個lambda表達式。

inline fun <T, R> with(receiver: T, block: T.() -> R): R {
    return receiver.block()
}

5.also

also函數(shù)和let函數(shù)類似,also也是把調用者作為參數(shù)傳遞給lambda,不同點是let返回的是lambda的執(zhí)行結果,而also返回的是當前調用者對象,這點和apply類似。

這對這個特點,可以實現(xiàn)調用者的鏈式調用。

舉個簡單列子。

雖然對hello做了substring,但并不會改變hello的初始值。因為最后返回的還是調用者對象本身。

    val hello = "Hello world".also {
        println(it.count())
    }.also{
        println(it.substring(0,5))
    }
    println(hello)

源碼分析:

block: (T) -> Unit also接收一個lambda,這個lambda把調用者T當參數(shù)傳進來了,block(this)。

return this 又把當前對象返回回去了。

inline fun <T> T.also(block: (T) -> Unit): T {
    block(this)
    return this
}

6.takeIf

takeIf需要判斷l(xiāng)ambda表達式中結果,如果true則返回調用者對象,如果是false,則返回null。

如果需要判斷某個條件是否滿足,再決定是否可以給變量賦值或執(zhí)行某項任務時,takeIf就很好用。takeIf類似于if語句。

示例:如果flag為true,則給hello賦值“Hello world”。

如果flag為false,則返回null,但是后面又有一個?:判斷,就會給hello賦值“hello null”

    var flag = false
    val hello = "Hello world".takeIf { false } ?: "hello null"
    println(hello)

源碼分析:

從if (predicate(this)) this else null可以看出,如果predicate(this)為true則返回調用者this否則返回null

 inline fun <T> T.takeIf(predicate: (T) -> Boolean): T? {
    return if (predicate(this)) this else null
}

通過源碼分析,takeIf也會把調用者T當做參數(shù)傳到lambda中,這樣我們在lambda中就可以針對調用者做判斷,滿足某些條件則返回調用者對象,如果不滿足,則返回null。

    val hello = "Hello world".takeIf {
        it.count() > 15
    } ?: "hello kotlin world"
    println(hello)

7.takeUnless

takeUnless剛好和takeIf相反,只有給定條件為false時,才會返回takeUnless調用者對象,否則返回null。

    val hello = "Hello world".takeUnless {
        it.count() > 15
    } ?: "hello kotlin world"
    println(hello)

源碼:

if (!predicate(this)) 剛好和takeIf中的相反。

inline fun <T> T.takeUnless(predicate: (T) -> Boolean): T? {
    return if (!predicate(this)) this else null
}

到此這篇關于Kotlin標準庫函數(shù)使用分析及介紹的文章就介紹到這了,更多相關Kotlin標準庫函數(shù)內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Kotlin?掛起函數(shù)CPS轉換原理解析

    Kotlin?掛起函數(shù)CPS轉換原理解析

    這篇文章主要為大家介紹了Kotlin?掛起函數(shù)CPS轉換原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • Android實現(xiàn)字母導航控件的示例代碼

    Android實現(xiàn)字母導航控件的示例代碼

    這篇文章主要介紹了通過自定義View實現(xiàn)字母導航控件的示例代碼,文中的實現(xiàn)過程講解詳細,對我們學習或工作有一定幫助,感興趣的可以學習一下
    2022-01-01
  • Android框架RePlugin使用詳解

    Android框架RePlugin使用詳解

    這篇文章給大家分享了Android 插件化框架 RePlugin使用心得,對此有興趣的朋友參考學習下。
    2018-07-07
  • android用鬧鐘定時做http請求推送的解決方案

    android用鬧鐘定時做http請求推送的解決方案

    這篇文章主要為大家詳細介紹了android用鬧鐘定時做http請求推送的解決方案,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • 安卓(android)怎么實現(xiàn)下拉刷新

    安卓(android)怎么實現(xiàn)下拉刷新

    這里我們將采取的方案是使用組合View的方式,先自定義一個布局繼承自LinearLayout,然后在這個布局中加入下拉頭和ListView這兩個子元素,并讓這兩個子元素縱向排列。對安卓(android)怎么實現(xiàn)下拉刷新的相關知識感興趣的朋友一起學習吧
    2016-04-04
  • Android編程實現(xiàn)TextView部分顏色變動的方法

    Android編程實現(xiàn)TextView部分顏色變動的方法

    這篇文章主要介紹了Android編程實現(xiàn)TextView部分顏色變動的方法,涉及Android針對TextView樣式操作的相關技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-11-11
  • Android實現(xiàn)檢測手機多點觸摸點數(shù)

    Android實現(xiàn)檢測手機多點觸摸點數(shù)

    這篇文章主要為大家詳細介紹了Android實現(xiàn)檢測手機多點觸摸點數(shù),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • Android入門教程之創(chuàng)建樣式與主題

    Android入門教程之創(chuàng)建樣式與主題

    通過這篇文章你將學到如何創(chuàng)建自定義的樣式和主題,并且你還能學到如何使用Android Studio的工具和快捷方式來加快樣式的創(chuàng)建。下面來一起看看吧。
    2016-08-08
  • Android 獲取 usb 權限的兩種方法

    Android 獲取 usb 權限的兩種方法

    這篇文章主要介紹了Android 獲取 usb 權限的兩種方式,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-10-10
  • Android studio 3.5.2安裝圖文教程詳解

    Android studio 3.5.2安裝圖文教程詳解

    這篇文章主要介紹了Android studio 3.5.2安裝教程,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-03-03

最新評論