kotlin快速入門之標(biāo)準(zhǔn)函數(shù)與靜態(tài)方法
標(biāo)準(zhǔn)函數(shù)
首先我們介紹標(biāo)準(zhǔn)函數(shù) with、run、apply,如果你了解javascript,那理解kotlin的標(biāo)準(zhǔn)函數(shù)width、run、apply那簡(jiǎn)直不要太輕松。with、run、apply與javascript中的with的意義基本一模一樣,只是含有一些細(xì)微差別。
with
with它接收兩個(gè)參數(shù),第一個(gè)參數(shù)可以是任意類型的對(duì)象,第二個(gè)參數(shù)是一個(gè)Lambda表達(dá)式。with函數(shù)會(huì)在Lambda表達(dá)式中提供第一個(gè)對(duì)象的上下文,可以直接使用對(duì)象的屬性或方法,而不需要帶上對(duì)象前綴。with函數(shù)會(huì)使用Lambda表達(dá)式中的最后一行代碼作為返回值返回。
val result = with(obj) { // 這里是obj的上下文環(huán)境 doSomething() // 調(diào)用obj的doSomething方法,無(wú)需 obj.doSomething() 這種形式調(diào)用 }
run
run函數(shù)的用法與使用場(chǎng)景和with函數(shù)非常類似,只是做了些許改動(dòng)。run函數(shù)無(wú)法直接調(diào)用,他需要在某個(gè)對(duì)象的基礎(chǔ)上去調(diào)用它;其次run函數(shù)值接收一個(gè)Lambda表達(dá)式作為參數(shù),并且會(huì)在Lambda表達(dá)中提供調(diào)用對(duì)象的上下文,同樣將Lambda表達(dá)式中的最后一行代碼作為返回值。
val result = obj.run { // 這里是obj的上下文環(huán)境 doSomething() // 調(diào)用obj的doSomething方法,無(wú)需 obj.doSomething() 這種形式調(diào)用 }
apply
apply函數(shù)和run函數(shù)在用法上基本一模一樣,唯一區(qū)別是apply函數(shù)不會(huì)將Lambda表達(dá)式中的最后一行作為參數(shù)返回,而是會(huì)返回對(duì)象本身.
val result = obj.apply { // 這里是obj的上下文環(huán)境 doSomething() // 調(diào)用obj的doSomething方法,無(wú)需 obj.doSomething() 這種形式調(diào)用 } // result == obj
靜態(tài)方法
在java中定義一個(gè)靜態(tài)方法如下:
public class Util { public static void doSome() { // todo } } // 使用靜態(tài)方法 Util.doSome()
而Kotlin提供了幾種方式去實(shí)現(xiàn)類似java中的靜態(tài)方法
單例類實(shí)現(xiàn)靜態(tài)方法
// 聲明一個(gè)單例類 object Util { fun doSome() { // todo } } // 使用 Util.doSome()
伴生類實(shí)現(xiàn)靜態(tài)方法
單例類的寫法會(huì)讓類中的所有方法全部變成了類似靜態(tài)方法的調(diào)用形式,如果我們只是希望類中的某些方法變成靜態(tài)方法的調(diào)用形式怎么辦呢?kotlin給我們提供了伴生類 companion object。
class Utl { companion obj { fun doSome() { // todo } } } // 使用 Util.doSome()
這個(gè)關(guān)鍵字實(shí)際會(huì)在Util類的內(nèi)部創(chuàng)建一個(gè)伴生類,Kotlin會(huì)保證一個(gè)類中只會(huì)存在一個(gè)伴生類對(duì)象,調(diào)用Util.doSome()實(shí)際上是調(diào)用Util類中的伴生類對(duì)象的doSome方法。
注解實(shí)現(xiàn)靜態(tài)方法
如果我們確確實(shí)實(shí)需要定義真正的靜態(tài)方法,我們可以給單例類或companion object伴生類中的方法加上 @JvmStatic注解,那么kotlin編譯器就會(huì)將這些方法編譯成真正的靜態(tài)方法。注意這個(gè)注釋一般加在單例類或伴生類的方法上,如果加在普通方法上,會(huì)直接提示語(yǔ)法錯(cuò)誤。
class Utl { companion obj { @JvmStatic fun doSome() { // todo } } } // 使用 Util.doSome()
頂層方法實(shí)現(xiàn)靜態(tài)方法
頂層方法指的是哪些沒(méi)有定義在任何類中的方法,比如我們編寫的main()方法。kotlin編譯器會(huì)將所有的頂層方法全部編譯成靜態(tài)方法。所有的頂層方法在任何位置可以直接被調(diào)用,不用管包名路徑,也不用創(chuàng)建實(shí)例。但如果這個(gè)方法在Java代碼中調(diào)用,需要加上該方法所在的文件名。
// 如我們?cè)赥ool.kt 文件中創(chuàng)建了一個(gè)頂層方法 // Tool.kt fun doSome() { // todo } // 在java代碼中使用 public class JavaTest { public void invokeStaticFunc() { // 文件名+方法形式調(diào)用頂層方法 Tool.doSome() } }
總結(jié)
到此這篇關(guān)于kotlin快速入門之標(biāo)準(zhǔn)函數(shù)與靜態(tài)方法的文章就介紹到這了,更多相關(guān)kotlin標(biāo)準(zhǔn)函數(shù)與靜態(tài)方法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java中synchronized(同步代碼塊和同步方法)詳解及區(qū)別
這篇文章主要介紹了 java中synchronized(同步代碼塊和同步方法)詳解及區(qū)別的相關(guān)資料,需要的朋友可以參考下2017-02-02SpringBoot集成MyBatisPlus+MySQL的實(shí)現(xiàn)
MybatisPlus是國(guó)產(chǎn)的第三方插件, 它封裝了許多常用的CURDapi,免去了我們寫mapper.xml的重復(fù)勞動(dòng),本文主要介紹了SpringBoot集成MyBatisPlus+MySQL的實(shí)現(xiàn),感興趣的可以了解一下2023-10-10mybatis中實(shí)現(xiàn)枚舉自動(dòng)轉(zhuǎn)換方法詳解
在使用mybatis的時(shí)候經(jīng)常會(huì)遇到枚舉類型的轉(zhuǎn)換,下面這篇文章主要給大家介紹了關(guān)于mybatis中實(shí)現(xiàn)枚舉自動(dòng)轉(zhuǎn)換的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-08-08java應(yīng)用開(kāi)發(fā)之Mybatis通過(guò)Mapper代理自定義接口的實(shí)現(xiàn)
這篇文章主要介紹了java應(yīng)用開(kāi)發(fā)之Mybatis通過(guò)Mapper代理自定義接口的實(shí)現(xiàn)方式,有需要的朋友可以借鑒參考下,希望能夠有所幫助2021-09-09利用反射獲取Java類中的靜態(tài)變量名及變量值的簡(jiǎn)單實(shí)例
下面小編就為大家?guī)?lái)一篇利用反射獲取Java類中的靜態(tài)變量名及變量值的簡(jiǎn)單實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-12-12Spring實(shí)戰(zhàn)之緩存使用key操作示例
這篇文章主要介紹了Spring實(shí)戰(zhàn)之緩存使用key操作,結(jié)合實(shí)例形式分析了Spring緩存使用key具體配置、屬性、領(lǐng)域模型等相關(guān)操作技巧,需要的朋友可以參考下2020-01-01完美解決java讀取大文件內(nèi)存溢出的問(wèn)題
下面小編就為大家?guī)?lái)一篇完美解決java讀取大文件內(nèi)存溢出的問(wèn)題。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-08-08