Kotlin靜態方法的使用淺析

在Java中定義一個靜態方法非常之簡單,隻需要在方法上聲明一個static關鍵字就可以瞭:

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

上述代碼中doAction()方法是一個靜態方法,調用靜態的方法並不需要創建實例,因而靜態方法非常適合用於編寫一些工具類,因為工具類並沒有創建實例的必要,基本都是全局通用

和絕大部分不同的是,Kotlin極度弱化瞭靜態方法的這個概念,想要在Kotlin中定義一個靜態的方法反而倒不是一件容易的事。

那麼Kotlin為什麼要這麼設計呢,因為Kotlin提供瞭比靜態方法更好用的語法特性,就是單例類。

像工具類這種功能,在Kotlin中直接推薦單例類的方式來實現,比如上述的Util工具類,在Kotlin中可以這麼寫:

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

單例類的會影響,類中所有的方法全部變成類似靜態方法的調用方式,而如果我們隻希望讓類中的某一個方法變成靜態方法調用方式可以采用如下寫法:

class Util {
    fun doAction(){
        println("do action")
    }
    companion object{
        fun doAction2(){
            println("do action2")
        }
    }
}

這裡在companion object 代碼塊中定義瞭一個doAction2()方法。現在Util類中的兩個方法就有瞭本質的區別,doAction()方法一定要先創建Util類的實例才能調用,而doAction2()方法就可以直接使用Util.doAction2()的方式調用。

不過doAction2方法也不並不是靜態方法,companion object 這個關鍵字實際上會在Util類的內部創建一個伴生類,而doAction2方法就是定義在伴生類裡面的實例方法。隻是Kotlin會保證Util類始終隻會存在一個伴生類對象,因此調用Util.doAction2方法實際上就是調用瞭Util類中的伴生對象的doAction2方法

由此可見,Kotlin確實沒有直接定義靜態方法的關鍵字,但是提供瞭一些語法特性來支持類似於靜態方法調用的寫法。

如果你確確實實要定義真的靜態方法嗎,Kotlin仍然提供瞭兩種實現方法,註解和頂層方法。

頂層方法這篇文章不做講解,請查找其他文章。

來看註解,前面使用的單例類和companion object 都隻是語法上模仿瞭靜態方法的調用方式,如果你在java代碼中以靜態方法的形式去調用的話,你會發現,這些方法並不存在。而如果我們給單例類或者companion object 中的方法加上 @JvmStatic 註解,那麼Kotlin在編譯器就會將這些方法編譯成真正的靜態方法

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

註意,@JvmStatic 註解隻能加載單例類或companion object中的方法上,如果嘗試添加到普通方法上,會直接提示語法錯誤。

這樣不管是在Kotlin和Java中,都可以使用Util.doAction2()的寫法來調用瞭。

到此這篇關於Kotlin靜態方法的使用淺析的文章就介紹到這瞭,更多相關Kotlin靜態方法內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: