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)方法
單例類的寫(xiě)法會(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)有定義在任何類中的方法,比如我們編寫(xiě)的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)文章
jdk17+springboot使用webservice的踩坑實(shí)戰(zhàn)記錄
這篇文章主要給大家介紹了關(guān)于jdk17+springboot使用webservice踩坑的相關(guān)資料,網(wǎng)上很多教程是基于jdk8的,所以很多在17上面跑不起來(lái),折騰兩天,直接給答案,需要的朋友可以參考下2024-01-01
Kotlin 開(kāi)發(fā)環(huán)境詳解及簡(jiǎn)單實(shí)例
這篇文章主要介紹了 Kotlin 開(kāi)發(fā)環(huán)境詳解及簡(jiǎn)單實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-06-06
Mybatis中攔截器的簡(jiǎn)單實(shí)現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于Mybatis中攔截器的簡(jiǎn)單實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Mybatis具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
Java生成指定范圍內(nèi)的一個(gè)隨機(jī)整數(shù)2種方式
本文主要介紹了Java生成指定范圍內(nèi)的一個(gè)隨機(jī)整數(shù)2種方式,主要使用Math.random()和Random.nextInt()這兩種,具有一定的參考價(jià)值,感興趣的可以了解一下2023-04-04
SpringBoot集成MybatisPlus報(bào)錯(cuò)的解決方案
這篇文章主要介紹了SpringBoot集成MybatisPlus報(bào)錯(cuò)的解決方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12

