欧美大屁股bbbbxxxx,狼人大香伊蕉国产www亚洲,男ji大巴进入女人的视频小说,男人把ji大巴放进女人免费视频,免费情侣作爱视频

歡迎來到入門教程網(wǎng)!

Java

當(dāng)前位置:主頁(yè) > 軟件編程 > Java >

Java里的static在Kotlin里如何實(shí)現(xiàn)

來源:本站原創(chuàng)|時(shí)間:2020-01-10|欄目:Java|點(diǎn)擊: 次

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 = 100
StaticTest.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 = 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方法來實(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來初始化的。而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ū)別了。

總結(jié):

本文的知識(shí)點(diǎn)總結(jié)如下:

  • java的靜態(tài)變量和方法,在kotlin中使用伴生對(duì)象替代
  • java的靜態(tài)初始化,在kotlin中使用伴生對(duì)象的init替代
  • java的靜態(tài)內(nèi)部類,在kotlin中使用嵌套類來替代

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持我們。

上一篇:SpringBoot靜態(tài)視頻實(shí)時(shí)播放的實(shí)現(xiàn)代碼

欄    目:Java

下一篇:Spring AOP定義Before增加實(shí)戰(zhàn)案例詳解

本文標(biāo)題:Java里的static在Kotlin里如何實(shí)現(xiàn)

本文地址:http://mengdiqiu.com.cn/a1/Java/8750.html

網(wǎng)頁(yè)制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語(yǔ)言數(shù)據(jù)庫(kù)服務(wù)器

如果侵犯了您的權(quán)利,請(qǐng)與我們聯(lián)系,我們將在24小時(shí)內(nèi)進(jìn)行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有