欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

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

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

公司專注于為企業(yè)提供成都做網(wǎng)站、網(wǎng)站制作、微信公眾號(hào)開發(fā)、商城網(wǎng)站定制開發(fā),成都小程序開發(fā),軟件按需開發(fā)網(wǎng)站等一站式互聯(lián)網(wǎng)企業(yè)服務(wù)。憑借多年豐富的經(jīng)驗(yàn),我們會(huì)仔細(xì)了解各客戶的需求而做出多方面的分析、設(shè)計(jì)、整合,為客戶設(shè)計(jì)出具風(fēng)格及創(chuàng)意性的商業(yè)解決方案,創(chuàng)新互聯(lián)更提供一系列網(wǎng)站制作和網(wǎng)站推廣的服務(wù)。

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)方式大家都非常熟悉了,下面著重說(shuō)說(shuō)kotlin是如何實(shí)現(xiàn)的。

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

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

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

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

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

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

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

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

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

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

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

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

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

還是拿上面的例子,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 = 100
StaticTest.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 init
100

在kotlin里,因?yàn)閖ava的靜態(tài)變量及方法都是放在伴生對(duì)象里實(shí)現(xiàn)的,而伴生對(duì)象也是一個(gè)普通對(duì)象,所以可以通過伴生對(duì)象的init方法來(lái)實(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 init
100

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

場(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ǔ)法上說(shuō),二值的差別就是前者多一個(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里怎么實(shí)現(xiàn)”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

分享文章:Java里的static在Kotlin里怎么實(shí)現(xiàn)
地址分享:http://www.chinadenli.net/article40/igjeho.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供軟件開發(fā)網(wǎng)站排名關(guān)鍵詞優(yōu)化域名注冊(cè)營(yíng)銷型網(wǎng)站建設(shè)外貿(mào)建站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運(yùn)營(yíng)