Kotlin常用函數(shù)let,with,run,apply用法與區(qū)別案例詳解
在kotlin編程中l(wèi)et、with、run、apply這些函數(shù)使用率是非常高的,有時候可以通用,差別很小,但如果能記住他們的不同點,可以更加合理的選擇使用。
在這之前首先要了解一下Lambda表達(dá)式的一些規(guī)則,這會幫助你理解使用這些函數(shù)的時候有沒有( )可不可以用it代替參數(shù)等。因為這些函數(shù)的最后一個參數(shù)都是lambda。
如何理解lambda呢?可以把lambda理解為就是一個對象,但這個對象比較特殊,它是一段代碼,既然是對象就可以作為函數(shù)的參數(shù)使用。這種對象稱為函數(shù)對象。
lambda表達(dá)式的語法格式舉例:
{ x: Int, y: Int -> x + y }
lambda 表達(dá)式是括在“{ }”中, “ ->” 前面為lambda參數(shù),后面為函數(shù)體。為了方便理解用普通函數(shù)推導(dǎo)一下變化過程:
fun sum(x: Int, y: Int) = x + y
首先去掉了關(guān)鍵字fun和方法名:
(x: Int, y: Int) = x + y
之后分為了2部分,“=” 前面作為lambda參數(shù),后面作為函數(shù)體,中間用“->” 代替:
(x: Int, y: Int) -> x + y
最后去掉參數(shù)的小括號,在外面加上大括號:
{x: Int, y: Int -> x + y}
最終得到的lambda表達(dá)式就可以作為參數(shù)使用了:
fun useLambda(a: Int, {x: Int, y: Int -> x + y}){ ...代碼省略... }
了解了基礎(chǔ)的語法格式后,在來看下,lambda的幾個重要規(guī)則:
Kotlin規(guī)則1:如果函數(shù)的最后一個參數(shù)是lambda,lambda 表達(dá)式可以放在圓括號之外(拖尾 lambda):
val result = useLambda(a: Int){x: Int, y: Int -> x + y}
Kotlin規(guī)則2:如果函數(shù)只有l(wèi)ambda一個參數(shù)時候,圓括號可以省略:
修改了useLambda函數(shù): fun useLambda({str: String -> str.length}){ ...代碼省略... } 規(guī)則1改為: val result = useLambda(){str: String -> str.length} 規(guī)則2改為: val result = useLambda{str: String -> str.length}
Kotlin規(guī)則3:如果lambda表達(dá)式只有一個參數(shù)時候,不用聲明參數(shù),可以用隱式名稱it代替參數(shù):
val result = useLambda{it.length}
Kotlin規(guī)則4:lambda表達(dá)式中有參數(shù)未使用的時候,可用下劃線“_” 代替
useLambda(){_, y -> y * y}
了解了lambda表達(dá)式之后再來分析函數(shù)
let函數(shù)用法:
val result = obj.let { //TODO 使用it訪問obj對象的方法或者屬性 it.xxx() //TODO 最后一行代碼的結(jié)果為返回值賦值給result }
從let函數(shù)寫法和lambda的規(guī)則可以看出,它只有一個lambda參數(shù),并且這個lambda的參數(shù)也只有一個,就是調(diào)用者對象本身。let最常用于判斷對象空指針之后有連續(xù)操作的場景。舉例:
obj?.let{ it.dosomething1() it.dosomething2() it.dosomething3() }
with函數(shù)用法:
val result = with(obj) { //TODO 直接訪問obj對象的方法或者屬性,或者使用this.調(diào)用 //TODO 最后一行代碼的結(jié)果為返回值賦值給result }
同樣我們可以看出,with函數(shù)有2個參數(shù),第一個參數(shù)為要處理的對象,最后一個是lambda參數(shù),根據(jù)規(guī)則1,放在了圓括號后邊。在這個lambda表達(dá)式中提供了第一個參數(shù)的對象可以用this指定,也可以省略。
run函數(shù)用法:
val result = obj.run{ //TODO 直接訪問obj對象的方法或者屬性,或者使用this.調(diào)用 //TODO 最后一行代碼的結(jié)果為返回值賦值給result }
run函數(shù)只有一個lambda參數(shù),run看上去是let與with的結(jié)合。因為run可以解決判空調(diào)用還可以去掉“it”解決let函數(shù)隱式名稱調(diào)用問題。
apply函數(shù)用法:
val result = obj.apply{ //TODO 直接訪問obj對象的方法或者屬性,或者使用this.調(diào)用 }
可以看出與run函數(shù)幾乎一樣,唯一的區(qū)別是lambda中沒有指定返回值。返回的是調(diào)用者對象本身,也就是obj。
總結(jié):
函數(shù) | 參數(shù)個數(shù) | 內(nèi)部訪問上下文對象 | 返回值 |
---|---|---|---|
let | 1 | it | lambda最后一行代碼返回值 |
with | 2 | this 或者 省略 | lambda最后一行代碼返回值 |
run | 1 | this 或者 省略 | lambda最后一行代碼返回值 |
apply | 1 | this 或者 省略 | 返回調(diào)用者對象 |
到此這篇關(guān)于Kotlin常用函數(shù)let,with,run,apply用法與區(qū)別案例詳解的文章就介紹到這了,更多相關(guān)Kotlin常用函數(shù)let,with,run,apply用法與區(qū)別內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot上傳文件并配置本地資源映射來訪問文件的實例代碼
這篇文章主要介紹了SpringBoot上傳文件并配置本地資源映射來訪問文件的實例代碼,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04idea打開項目后無法顯示目錄結(jié)構(gòu),只能顯示.iml文件問題
這篇文章主要介紹了idea打開項目后無法顯示目錄結(jié)構(gòu),只能顯示.iml文件問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08Spring Boot與RabbitMQ結(jié)合實現(xiàn)延遲隊列的示例
本篇文章主要介紹了Spring Boot與RabbitMQ結(jié)合實現(xiàn)延遲隊列的示例,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-11-11SparkSQL讀取hive數(shù)據(jù)本地idea運行的方法詳解
這篇文章主要介紹了SparkSQL讀取hive數(shù)據(jù)本地idea運行的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09springboot中restful風(fēng)格請求的使用方法示例
RESTful是一種web軟件風(fēng)格,它不是標(biāo)準(zhǔn)也不是協(xié)議,它不一定要采用,只是一種風(fēng)格,它倡導(dǎo)的是一個資源定位(url)及資源操作的風(fēng)格,下面這篇文章主要給大家介紹了關(guān)于springboot中restful風(fēng)格請求的使用方法,需要的朋友可以參考下2023-02-02Java數(shù)據(jù)結(jié)構(gòu)之紅黑樹的實現(xiàn)方法和原理詳解
這篇文章主要介紹了Java數(shù)據(jù)結(jié)構(gòu)之紅黑樹的實現(xiàn)方法和原理,紅黑樹是一種特殊的二叉查找樹,每個結(jié)點都要儲存位表示結(jié)點的顏色,或紅或黑,本文將通過示例為大家詳細(xì)講講紅黑樹的原理及實現(xiàn),感興趣的朋友可以了解一下2024-02-02