溫馨提示×

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

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

Java里的static在Kotlin里怎么實(shí)現(xiàn)

發(fā)布時(shí)間:2021-02-02 10:08:00 來(lái)源:億速云 閱讀:216 作者:小新 欄目:編程語(yǔ)言

小編給大家分享一下Java里的static在Kotlin里怎么實(shí)現(xiàn),相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

static修飾符是java里面非常常用的一個(gè)東西,用法也非常多。然而,在kotlin里竟然沒(méi)有這個(gè)東西!那該如何替代呢?本文就總結(jié)了下java里面static的幾種常見(jiàn)用法在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)方式大家都非常熟悉了,下面著重說(shuō)說(shuō)kotlin是如何實(shí)現(xiàn)的。

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

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

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

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

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

    fun staticMethod(str: String?) {
      println(str)
    }
  }
}

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

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

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

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

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

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

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

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

//通過(guò)類引用訪問(wèn)
StaticTest.STATIC_VAR = 10; 
StaticTest.staticMethod("hello");

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

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

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

//使用類引用訪問(wèn)
StaticTest.STATIC_VAR = 100
StaticTest.staticMethod("hello")
  
//不能使用對(duì)象引用訪問(wèn)
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 init
100

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

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

    init {
      STATIC_VAR = 100
      println("in companion object init")
    }
  }
}

執(zhí)行代碼:

println(StaticTest.STATIC_VAR)

結(jié)果如下:

in companion object init
100

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

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

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

public class StaticTest {
  
  private int out = 0;
  
  class InnerClass{
    public void InnerClassMethod(){
      out = 100; //可以訪問(wèn)外部類的變量
    }
  }

  static class StaticInnerClass{
    public void StaticInnerClassMethod(){
      out = 100; //編譯錯(cuò)誤,不可以訪問(wèn)外部類的變量
    }
  }
}

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

下面是和java的比較:

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

  • kotlin的嵌套類(沒(méi)有inner修飾符)相當(dāng)于java的靜態(tài)內(nèi)部類,不可以訪問(wèn)外部變量

kotlin嵌套類的例子:

class StaticTest {
  var out = 0

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

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

class StaticTest {
  var out = 0

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

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

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

向AI問(wèn)一下細(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