溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Java中static在Kotlin中怎么用

發(fā)布時(shí)間:2021-03-05 15:13:05 來源:億速云 閱讀:271 作者:小新 欄目:編程語(yǔ)言

小編給大家分享一下Java中static在Kotlin中怎么用,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

static修飾符是java里面非常常用的一個(gè)東西,用法也非常多。然而,在kotlin里竟然沒有這個(gè)東西!那該如何替代呢?本文就總結(jié)了下java里面static的幾種常見用法在kotlin里的替代方式。

static在java里面的用法總結(jié)

static在java里面的用法有很多,最常用的有下面幾種:

靜態(tài)變量及方法  靜態(tài)初始化  靜態(tài)內(nèi)部類

下面我們就看看這幾種場(chǎng)景在kotlin是如何實(shí)現(xiàn)的。

場(chǎng)景一:靜態(tài)變量及方法

靜態(tài)變量及方法可能是我們平時(shí)用到static最多的地方,我們先看看java里面是如何做的。

java靜態(tài)變量及方法介紹:

首先,是靜態(tài)變量和方法的定義:

public class StaticTest {  public static int STATIC_VAR = 0;  public static void staticMethod(String str){    System.out.println(str);  }}

然后是靜態(tài)變量和方法的使用:

StaticTest.STATIC_VAR = 10;StaticTest.staticMethod("hello");

java的實(shí)現(xiàn)方式大家都非常熟悉了,下面著重說說kotlin是如何實(shí)現(xiàn)的。

kotlin替代靜態(tài)變量及方法的方案

kotlin通過引入“伴生對(duì)象”的概念來替代java里的靜態(tài)變量及方法。

“伴生對(duì)象”這個(gè)名詞聽上去很古怪,其實(shí)非常簡(jiǎn)單:在類的內(nèi)容使用companion來標(biāo)記一個(gè)對(duì)象。所有需要“靜態(tài)化”的變量和方法都放在這個(gè)對(duì)象里。

下面是定義伴生對(duì)象的代碼:

class StaticTest {  companion object{//伴生對(duì)象是可以指定名字的,不過一般都省略掉。    var STATIC_VAR = 0    fun staticMethod(str: String?) {      println(str)    }  }}

接下來看看如何使用伴生對(duì)象,伴生對(duì)象只能通過類名來訪問,使用方法和java差不多:

StaticTest.STATIC_VAR = 100StaticTest.staticMethod("hello")

kotlin的伴生對(duì)象解決了什么問題?

大家可能會(huì)好奇,為什么kotlin要用這么一個(gè)奇怪的方式來解決這個(gè)問題呢?

我的理解是有兩個(gè)原因:

第一,使用伴生對(duì)象體現(xiàn)了kotlin一貫的設(shè)計(jì)理念:一切都是對(duì)象!伴生對(duì)象也是對(duì)象!而java的static,顯然和對(duì)象沒有關(guān)系。

第二,伴生對(duì)象解決了java靜態(tài)變量及方法的一個(gè)常見的反模式:靜態(tài)方法及變量可以通過對(duì)象的引用來訪問。

還是拿上面的例子,java的靜態(tài)變量及方法可以通過類引用和對(duì)象引用兩種方法訪問:

//通過類引用訪問StaticTest.STATIC_VAR = 10; StaticTest.staticMethod("hello");//通過對(duì)象引用訪問StaticTest obj = new StaticTest();obj.STATIC_VAR = 10;obj.staticMethod("hello");

而通過對(duì)象引用訪問靜態(tài)變量及方法,顯然是不合適的。但是在java里卻沒有辦法從語(yǔ)法層面避免這個(gè)問題。

而kotlin的伴生對(duì)象只能通過類引用訪問,從語(yǔ)法的層面解決了這個(gè)問題:

//使用類引用訪問StaticTest.STATIC_VAR = 100StaticTest.staticMethod("hello")  //不能使用對(duì)象引用訪問val obj = StaticTest()obj.STATIC_VAR = 100 //編譯錯(cuò)誤obj.staticMethod("hello") //編譯錯(cuò)誤

總之,kotlin里每個(gè)新的語(yǔ)言特性,都是為了填補(bǔ)java的某一個(gè)坑。

場(chǎng)景二:靜態(tài)初始化

java里的靜態(tài)初始化可以在類加載的時(shí)候初始化一些靜態(tài)變量,比如:

public class StaticTest {  public static int STATIC_VAR = 0;    static {    STATIC_VAR = 100;    System.out.println("in static init");  }    public static void main(String[] args) {    System.out.println(StaticTest.STATIC_VAR);  }}

上面的代碼執(zhí)行結(jié)果如下:

in static init100

在kotlin里,因?yàn)閖ava的靜態(tài)變量及方法都是放在伴生對(duì)象里實(shí)現(xiàn)的,而伴生對(duì)象也是一個(gè)普通對(duì)象,所以可以通過伴生對(duì)象的init方法來實(shí)現(xiàn)變量的初始化,代碼如下:

class StaticTest {  companion object{//伴生對(duì)象是可以指定名字的,不過一般都省略掉。    var STATIC_VAR = 0    init {      STATIC_VAR = 100      println("in companion object init")    }  }}

執(zhí)行代碼:

println(StaticTest.STATIC_VAR)

結(jié)果如下:

in companion object init100

可以看到,kotlin的實(shí)現(xiàn)方式要比java的更加一致,既然大家都是對(duì)象,所以都是通過init來初始化的。而java里,非靜態(tài)變量是通過構(gòu)造函數(shù)來初始化的,而靜態(tài)變量是通過static代碼塊來初始化的,兩者很不一致。

場(chǎng)景三:靜態(tài)內(nèi)部類

java的內(nèi)部類有兩種,普通內(nèi)部類和靜態(tài)內(nèi)部類。二者的區(qū)別是前者可以訪問外部類的變量,而后者不可以。同時(shí)普通內(nèi)部類會(huì)持有外部類的一個(gè)引用,靜態(tài)內(nèi)部類則沒有。

public class StaticTest {    private int out = 0;    class InnerClass{    public void InnerClassMethod(){      out = 100; //可以訪問外部類的變量    }  }  static class StaticInnerClass{    public void StaticInnerClassMethod(){      out = 100; //編譯錯(cuò)誤,不可以訪問外部類的變量    }  }}

而kotlin的內(nèi)部類也有兩種:內(nèi)部類和嵌套類。從語(yǔ)法上說,二值的差別就是前者多一個(gè)inner修飾符。

下面是和java的比較:

kotlin的內(nèi)部類(使用inner修飾符)相當(dāng)于java的普通內(nèi)部類,可以訪問外部變量,同時(shí)持有外部對(duì)象的引用。  kotlin的嵌套類(沒有inner修飾符)相當(dāng)于java的靜態(tài)內(nèi)部類,不可以訪問外部變量

kotlin嵌套類的例子:

class StaticTest {  var out = 0  inner class InnerClass{    fun InnerClassMethod(){      out = 100 //內(nèi)部類可以訪問外部變量    }  }}

kotlin內(nèi)部類的例子:

class StaticTest {  var out = 0  class InnerClass{    fun InnerClassMethod(){      out = 100 //編譯錯(cuò)誤,嵌套類不可以訪問外部變量    }  }}

通過對(duì)比,大家應(yīng)該很容易的搞清楚kotlin里內(nèi)部類和嵌套類的區(qū)別了。

以上是“Java中static在Kotlin中怎么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI