日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

Kotlin標準函數與靜態方法應用詳解_Android

作者:z啵唧啵唧 ? 更新時間: 2022-12-29 編程語言

標準函數

  • 標準函數就是在Standard.kt文件中定義的函數,任何Kotlin代碼都可以自由地調用所有的標準函數
  • let函數就屬于是一個標準函數,經常配合?.操作符來進行判空處理

with函數

with函數接收兩個參數,第一參數可以是任何類型的對象,第二個參數是一個Lambda表達式

with函數會在Lambda表達式中提供第一個參數的上下文,并使用Lambda表達式的最后一行代碼作為函數的返回值

示例代碼

val res = with(obj) {
    //這里是obj對象的上下文
    "value"http://這里是with函數的返回值
}

with函數的作用.假如現在有個需求讓吃完所有的水果并且將結果打印出來,代碼可以這樣寫

fun main() {
    doSomething()
}
fun doSomething() {
    val list = listOf<String>("Apple", "Banana", "Pear")
    val sb = StringBuilder()
    sb.append("Start eating fruits.\n")
    for (fruits in list) {
        sb.append(fruits).append("\n")
    }
    sb.append("Ate all fruits.")
    val res = sb.toString()
    println(res)
}

利用with函數可以這樣寫,可以看到在Lambda表達式中,都是StringBuilder的上下文,那么就不需要我們通過StringBuilder的實例調用append()方法了,而是直接使用append()方法即可.

fun withTest() {
    val list = listOf<String>("Apple", "Banana", "Pear")
    val res = with(StringBuilder()) {
        append("Start eating fruits.\n")
        for (fruits in list) {
            append(fruits)
            append("\n")
        }
        append("Ate all fruits.")
        toString()//最后一行就是函數的返回值
    }
    println(res)
}

run函數

  • run函數和with函數基本類似,區別就是,run函數不能直接調用,需要在某個對象的基礎上進行調用
  • 其次run函數只接受一個Lambda參數,并且在Lambda表達式中提供調用對象的上下文.
  • 其他和with函數都是一樣的
  • 使用run函數完成上述需求的實例
fun runTest() {
    val list = listOf<String>("Apple", "Banana", "Pear")
    //將StringBuilder調出來,用來調用run函數
    val res = StringBuilder().run {
        append("Start eating fruits.\n")
        for (fruits in list) {
            append(fruits)
            append("\n")
        }
        append("Ate all fruits.")
        toString()
    }
    println(res)
}

apply函數

  • apply函數和run函數基本一樣,就是apply函數不能指定返回值,只能返回調用調用者的本身
  • apply函數實例
fun applyTest() {
    val list = listOf<String>("Apple", "Banana", "Pear")
    val res = StringBuilder().apply {
        append("Start eating fruits.\n")
        for (fruits in list) {
            append(fruits)
            append("\n")
        }
        append("Ate all fruits.")
    }
    println(res.toString())
}

靜態方法

  • 靜態方法又叫做類方法,就是說不需要實例,直接用類就可以進行調用,一般會將工具類中的方法設置為靜態方法,方便調用
  • 在java當中的靜態方法就是使用static關鍵字修飾的方法
  • 但是在kotlin當中沒有直接的靜態方法

單例類

在kotlin當中要是想要定義一個工具類,會比較推薦單例類進行實現

object Util {
    fun doAction() {
        println("do something")
    }
}

雖然單例類中的doAction()方法并不是靜態放啊,但是我們還是可以直接使用Util.doAction()來進行調用

但是單例類的缺點是單例類中的方法都是類似靜態方法這種調用方式,但是我們只需要讓類中的一個方法變成靜態的怎么辦?

companion object

在companion object中定義的方法就可以類似于靜態方法那樣進行調用了

class Util {
    //非靜態方法屬性
    fun doAction1() {
    }
    //擁有靜態方法的屬性
    companion object {
        fun doAction2() {
        }
    }
}

注解

單例類和companion object都是在語法形式上模仿了靜態方法,實際上不屬于真正的靜態方法

如果我們給單例類或者companion object中的方法加上@JvmStatic注解,那么kotlin編譯器就會將這些方法編譯成為真正的靜態方法

如下

class Util {
    //非靜態方法屬性
    fun doAction1() {
    }
    //擁有靜態方法的屬性
    companion object {
        @JvmStatic
        fun doAction2() {
        }
    }
}

@JvmStatic只能加在單例類或者companion object中的方法

頂層方法

  • 頂層方法指的就是沒有定義在任何類中的方法,kotlin編譯器會將所有的頂層方法編譯成為靜態方法
  • 因此只要定義了一個頂層方法,那么他肯定是一個靜態方法

原文鏈接:https://blog.csdn.net/weixin_45809829/article/details/128019441

欄目分類
最近更新