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

Kotlin?標準函數(shù)和靜態(tài)方法示例詳解

 更新時間:2022年10月29日 11:28:28   作者:奔跑吧雞翅  
這篇文章主要為大家介紹了Kotlin?標準函數(shù)和靜態(tài)方法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

標準函數(shù)

with

with 的作用是可以在連續(xù)調用同一對象的多個方法時讓代碼變得更加精簡

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

看個例子,例如有一個水果列表,現(xiàn)在我們想吃完所有水果,并將結果打印出來

val list = listOf("Apple","Banana","Orange")
val builder = StringBuilder()
builder.append("Start eating fruits\n")
for(fruit in list){
	builder.append(fruit).append("\n")
}
builder.append("Ate all fruits.\n")
val result = builder.toString()
print(result)

Start eating fruitsApple
Banana
Orange
Ate all fruits.

我們可以使用 with 讓代碼更簡單

		val list = listOf("Apple","Banana","Orange")
        val result = with(StringBuffer()){
            append("Start eating fruit.\n")
            for (fruit in list){
                append(fruit+"\n")
            }
            append("Ate all fruits.\n")
            toString()
        }
        println(result)

我們給 with 函數(shù)第一個參數(shù)傳入 StringBuilder 對象,那么接下來整個 Lambda 表達式的上下文就是這個 StringBuilder。Lambda 表達式最后一行代碼會作為 with 函數(shù)的返回值返回

run

首先 run 函數(shù)是不能直接調用的,而是一定要調用某個對象的 run 函數(shù)才行;其次 run 函數(shù)只接收一個 Lambda 函數(shù),并且會在 Lambda 表達式中提供調用對象的上下文

val result = obj.run{
	//這里是obj的上下文
	"value"http://run函數(shù)的返回值
}
val list = listOf("Apple","Banana","Orange")
        val result = StringBuilder().run{
            append("Start eating fruit.\n")
            for (fruit in list){
                append(fruit+"\n")
            }
            append("Ate all fruits.\n")
            toString()
        }
        println(result)

Apply

apply 函數(shù)和 run 函數(shù)極其類似,只不過無法指定返回值,而是會自動返回調用對象本身

val result = obj.apply{
	//這里是obj的上下文
}
//result == obj
val list = listOf("Apple","Banana","Orange")
        val result = StringBuilder().apply{
            append("Start eating fruit.\n")
            for (fruit in list){
                append(fruit+"\n")
            }
            append("Ate all fruits.\n")
        }
        println(result.toString())

我們可以使用 apply 對啟動 Activity 的代碼進行優(yōu)化,傳遞的參數(shù)越多,這種寫法越有優(yōu)勢

val intent = Intent(this,SecondActivity::class.java).apply { 
	putExtra("param1","data1")
	putExtra("param2","data2")
}
startActivity(intent)

定義靜態(tài)方法

在 Java 中定義一個靜態(tài)方法非常簡單,只需要在方法前聲明 static 關鍵字即可

public class Util{
	public static void doAction(){
		System.out.println("do action");
	}
}

調用的時候

Util.doActin();

靜態(tài)方法非常適合編寫一些工具類的功能,因為工具類通常沒有創(chuàng)建實例的必要。而 Kotlin 中推薦使用單例類的方法來實現(xiàn),例如上述 Util 工具類

object Util {
    fun doAction(){
        println("do action")
    }
}

調用的時候

Util.doAction()

不過使用單例類的寫法會將整個類的所有方法全部變成類似于靜態(tài)方法的調用方式,而如果我們只想讓類中某個方法變成靜態(tài)方法的調用方式:

class Util {
    fun doAction1(){
        println("do action1")
    }
    companion object{
        fun doAction2(){
            println("do action2")
        }
    } 
}

我們將 Util 變成一個普通類,doAction1() 方法一定要創(chuàng)建 Util 類的實例才能調用,而 doAction2() 可以使用 Util.doAction2() 的方式調用。doAction2() 方法其實也不是靜態(tài)方法,companion object 關鍵字實際上會在 Util 類內(nèi)創(chuàng)建一個伴生類,而 doAction2() 方法就是定義在這個伴生類里面的實例方法,只是 Kotlin 會保證 Util 類始終只會存在一個伴生類對象,因此調用 Util.doAction2() 方法實際上就是調用了 Util 類中伴生對象的 Util.doAction2() 方法

由此可見 Kotlin 確實沒有直接定義靜態(tài)方法的關鍵字,而是提供了一些語法特性來支持類似靜態(tài)方法調用的寫法,然而如果你確確實實需要定義真正的靜態(tài)方法,Kotlin 仍然提供了兩張實現(xiàn)方式:注解和頂層方法

注解

如果我們給單例類或 Companion object 中的方法加上 @JvmStatic 注解,那么 Kotlin 編譯器就會將這些方法編譯成真正的靜態(tài)方法:

class Util {
    fun doAction1(){
        println("do action1")
    }
    companion object{
        @JvmStatic
        fun doAction2(){
            println("do action2")
        }
    }
}

注意@JvmStatic注解只能加到單例類或 companion object 中方法上。由于 doAction2() 方法已經(jīng)成為真正的靜態(tài)方法,不管在 Kotlin 還是 Java 中都可以使用 Util.doAction2() 的寫法來調用了

頂層方法

頂層方法指的是那些沒有定義在任何類中的方法,例如 main() 方法。Kotlin 編譯器會將所有頂層方法全部編譯成靜態(tài)方法。所以如果你定義了一個頂層方法,那么它就一定是靜態(tài)方法

現(xiàn)在創(chuàng)建一個 Helper.kt 的 File

現(xiàn)在在這個文件里定義的任何方法都是頂級方法

fun doSomething(){
    println("do something")
}

所有的頂層方法都可以在任何位置被直接調用,不用管包名路徑,也不用創(chuàng)建實例,直接輸入方法名即可:doSomething()。而在 Java 中不同了。Kotlin 編譯器會自動創(chuàng)建一個 HelperKt 的 Java 類,所以使用 HelpterKt.doSomething()即可

classJavaTest {
    public void invokeStaticMethod(){
        HelperKt . doSome thing();
    }
}

以上就是Kotlin 標準函數(shù)和靜態(tài)方法示例詳解的詳細內(nèi)容,更多關于Kotlin 標準函數(shù)靜態(tài)方法的資料請關注腳本之家其它相關文章!

相關文章

  • Java實現(xiàn)的獲取和判斷文件頭信息工具類用法示例

    Java實現(xiàn)的獲取和判斷文件頭信息工具類用法示例

    這篇文章主要介紹了Java實現(xiàn)的獲取和判斷文件頭信息工具類,結合實例形式分析了Java針對文件讀取及頭信息判斷相關操作技巧,需要的朋友可以參考下
    2017-11-11
  • SpringBoot集成支付寶支付的實現(xiàn)示例

    SpringBoot集成支付寶支付的實現(xiàn)示例

    本文主要介紹了SpringBoot集成支付寶支付的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-06-06
  • 詳解Java 中的UnitTest 和 PowerMock

    詳解Java 中的UnitTest 和 PowerMock

    這篇文章主要介紹了Java中的 UnitTest 和 PowerMock,文中講解非常詳細,對大家學習有很大的幫助,感興趣的朋友可以了解下
    2020-06-06
  • Java數(shù)據(jù)結構之順序表詳解

    Java數(shù)據(jù)結構之順序表詳解

    這篇文章主要介紹了Java數(shù)據(jù)結構之順序表詳解,線性表在邏輯上是線性結構,也就說是連續(xù)的一條直線。但是在物理結構上并不一定是連續(xù)的,線性表在物理上存儲時,通常以數(shù)組和鏈式結構的形式存儲,需要的朋友可以參考下
    2023-07-07
  • SpringBoot指標監(jiān)控功能實現(xiàn)

    SpringBoot指標監(jiān)控功能實現(xiàn)

    這篇文章主要介紹了SpringBoot指標監(jiān)控功能實現(xiàn),本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-06-06
  • Springboot2.3.x整合Canal的示例代碼

    Springboot2.3.x整合Canal的示例代碼

    canal是阿里開源mysql?binlog?數(shù)據(jù)組件,canal-server?才是canal的核心我們前邊所講的canal的功能,實際上講述的就是canal-server的功能,本文給大家介紹Springboot2.3.x整合Canal的示例代碼,需要的朋友可以參考下
    2022-02-02
  • 解決spring AOP中自身方法調用無法應用代理的問題

    解決spring AOP中自身方法調用無法應用代理的問題

    這篇文章主要介紹了解決spring AOP中自身方法調用無法應用代理的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • SpringBoot中讀取配置的七種方法總結

    SpringBoot中讀取配置的七種方法總結

    在Spring Boot應用中,讀取配置是一項基礎且重要的任務,Spring Boot提供了多種靈活的方式來讀取配置,以滿足不同場景下的需求,本文將詳細介紹Spring Boot中讀取配置的幾種常用方法,需要的朋友可以參考下
    2024-08-08
  • Java遺傳算法之沖出迷宮

    Java遺傳算法之沖出迷宮

    這篇文章首先詳細介紹了什么是遺傳算法,然后通過遺傳算法的思想用實例解析使用遺傳算法解決迷宮問題,需要的朋友可以參考下
    2017-09-09
  • Java中計算時間差的方法

    Java中計算時間差的方法

    這篇文章主要介紹了Java中計算時間差的方法,實例分析了java常見的三種計算時間差的技巧,需要的朋友可以參考下
    2015-06-06

最新評論