欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

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

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

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

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

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

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

  • 靜態(tài)變量及方法

  • 靜態(tài)初始化

  • 靜態(tài)內(nèi)部類

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

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

靜態(tài)變量及方法可能是我們平時用到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的實現(xiàn)方式大家都非常熟悉了,下面著重說說kotlin是如何實現(xiàn)的。

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

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

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

下面是定義伴生對象的代碼:

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

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

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

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

kotlin的伴生對象解決了什么問題?

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

我的理解是有兩個原因:

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

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

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

//通過類引用訪問
StaticTest.STATIC_VAR = 10; 
StaticTest.staticMethod("hello");

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

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

而kotlin的伴生對象只能通過類引用訪問,從語法的層面解決了這個問題:

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

總之,kotlin里每個新的語言特性,都是為了填補java的某一個坑。

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

java里的靜態(tài)初始化可以在類加載的時候初始化一些靜態(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里,因為java的靜態(tài)變量及方法都是放在伴生對象里實現(xiàn)的,而伴生對象也是一個普通對象,所以可以通過伴生對象的init方法來實現(xiàn)變量的初始化,代碼如下:

class StaticTest {
  companion object{//伴生對象是可以指定名字的,不過一般都省略掉。
    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的實現(xiàn)方式要比java的更加一致,既然大家都是對象,所以都是通過init來初始化的。而java里,非靜態(tài)變量是通過構(gòu)造函數(shù)來初始化的,而靜態(tài)變量是通過static代碼塊來初始化的,兩者很不一致。

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

java的內(nèi)部類有兩種,普通內(nèi)部類和靜態(tài)內(nèi)部類。二者的區(qū)別是前者可以訪問外部類的變量,而后者不可以。同時普通內(nèi)部類會持有外部類的一個引用,靜態(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; //編譯錯誤,不可以訪問外部類的變量
    }
  }
}

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

下面是和java的比較:

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

  • kotlin的嵌套類(沒有inner修飾符)相當于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 //編譯錯誤,嵌套類不可以訪問外部變量
    }
  }
}

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

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

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

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

廣告

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

網(wǎng)站托管運營
色噜噜噜av天堂九区| 夫妻性生活免费看视频| 黄色录像日本黄色录像| 中文字幕国产成人在线视频| 国家成人午夜在线观看| 日本性电影一区二区| 日韩在线一区二区视频| 亚洲理论电影在线观看| 亚洲午夜福利天堂社区| 天天操夜夜夜夜夜操| 久久国产精品av在线观看| 日韩av专区在线免费观看| 亚洲一区二区三区精品乱码| 日韩精品少妇一区二区在线看 | 青青草国产自拍在线视频| 日韩有码中文字幕av| 亚洲欧美二区中文字幕 | 亚洲精品成人一区不卡| 日韩一区二区精品网站| 亚洲男人天堂中文字幕| 伦理中文字幕一区二区| 天天日夜夜操人人干人人插| 国产欧美日韩另类在线播放| 91精品一区二区三区91人妻| 精品人妻av区天天看片| 日日嗨av特一级黄淫片| 韩国日本午夜福利在线| 国产一区二区高清在线| 久久99精品久久久子伦| 粉嫩在线一区二区懂色| 欧美香蕉视频播放二区| 亚洲理论电影在线观看| 黄色午夜福利在线观看| 日韩精品一区二区av在线| 日韩精品在线观看大全套| 中文字幕久久亚洲一区| 欧美日本国产老熟女视频| 日韩精品国产亚洲欧美| 日本一区二区手机在线| 日本黄网色三级三级三级| 日本欧美国产一区二区|