詳解Kotlin中的變量和方法
詳解Kotlin中的變量和方法
變量
Kotlin 有兩個關(guān)鍵字定義變量:var 和 val, 變量的類型在后面。
var 定義的是可變變量,變量可以被重復(fù)賦值。val 定義的是只讀變量,相當(dāng)于java的final變量。
變量的類型,如果可以根據(jù)賦值推測,可以省略。
var name: String = "jason" name = "jame" val max = 10
常量
Java 定義常量用關(guān)鍵字 static final, Kotlin 沒有static, 可以在命名對象里面用 const val 定義
object Config { const val TAG = "config" }
或者伴隨對象
class Config { companion object { const val TAG = "config" } }
方法
方法通過 fun 定義, 包含若干參數(shù)和返回值(可選)
fun log(msg: String): Unit { println(msg) }
方法沒有返回值用 Unit, 一般省略不寫。
單表達(dá)式方法
如果方法只有一個表達(dá)式,可以采用“=”的簡明寫法
fun square(x: Int) = x * x
頂層方法
Java 的方法都在 class 里面, Kotlin 支持頂層方法,這些方法定義在 class 的外面。
頂層方法一般是一些工具方法,和 Java 將這些方法勉強(qiáng)放到一個不關(guān)聯(lián)的類不同, 單獨(dú)提供這些方法似乎更合理。
fun main(args: ArrayList<String>) { // } class Hello() { // }
參數(shù)
Java 不支持默認(rèn)參數(shù), 只能通過重載定義多個方法,Kotlin支持, 帶默認(rèn)值的參數(shù)放后面。
fun divide(divisor: BigDecimal, scale: Int = 0): BigDecimal class Student2(val name: String, val registered: Boolean = false, credits: Int = 0)
當(dāng)調(diào)用方法時(shí),Kotlin支持命名參數(shù),這有助于提高代碼的可讀性,尤其是多參數(shù)的方法。帶名字的參數(shù)放后面。
fun deleteFiles(filePattern: String, recursive: Boolean, ignoreCase: Boolean, deleteDirectories: Boolean): Unit { // do something } deleteFiles("*.jpg", true, true, false) deleteFiles("*.jpg", recursive = true, ignoreCase = true, deleteDirectories = false)
不定長度參數(shù)
例如 java public void println(String.. args) { } 可以這樣定義不定個數(shù)參數(shù)的函數(shù)。
Kotlin 通過關(guān)鍵字 vararg 實(shí)現(xiàn)這個功能,如示例:
fun prints(vararg strings: String) { for (string in strings) println(string) } prints("a", "b", "c")
如果已經(jīng)有一個數(shù)組, 可以通過關(guān)鍵字*傳遞數(shù)組。
val strings = arrayOf("a", "b", "c", "d", "e") prints(*strings)
返回多個值
要返回多個值,可以返回?cái)?shù)組,或者自定義類型。Kotlin內(nèi)置了 Pair 和 Triple, 返回2個值和3個值。
fun roots(k: Int): Pair<Double, Double> { require(k >= 0) val root = Math.sqrt(k.toDouble()) return Pair(root, -root) } val (pos, neg) = roots(16)
尾遞歸函數(shù)(Tail recursive function)
當(dāng)一個函數(shù)標(biāo)記為tailrec , 并且滿足要求的形式, 編譯器就會對代碼進(jìn)行優(yōu)化, 消除函數(shù)的遞歸調(diào)用, 產(chǎn)生一段基于循環(huán)實(shí)現(xiàn)的, 快速而且高效的代碼。
tailrec fun findFixPoint(x: Double = 1.0): Double = if (x == Math.cos(x)) x else findFixPoint(Math.cos(x))
上面的代碼計(jì)算余弦函數(shù)的不動點(diǎn)(fixpoint), 結(jié)果應(yīng)該是一個數(shù)學(xué)上的常數(shù)。這個函數(shù)只是簡單地從 1.0 開始不斷重復(fù)地調(diào)用 Math.cos 函數(shù), 直到計(jì)算結(jié)果不再變化為止, 計(jì)算結(jié)果將是 0.7390851332151607。
要符合 tailrec 修飾符的要求, 函數(shù)必須在它執(zhí)行的所有操作的最后一步, 遞歸調(diào)用它自身。不能將尾遞歸用在 try/catch/finally 結(jié)構(gòu)內(nèi)。 尾遞歸目前只能用在 JVM 環(huán)境內(nèi)。
函數(shù)引用
和 C 語言的函數(shù)指針類似, 函數(shù)可以賦值給變量, 也可以作為高階函數(shù)的參數(shù)或者返回值,例如:
val printMessage = { message: String -> println(message) } printMessage("hello") printMessage("world")
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
堆排序?qū)嵗?Java數(shù)組實(shí)現(xiàn))
下面小編就為大家分享一篇使用Java數(shù)組實(shí)現(xiàn)堆排序的實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-12-12Java高級之虛擬機(jī)加載機(jī)制的實(shí)例講解
下面小編就為大家分享一篇Java高級之虛擬機(jī)加載機(jī)制的實(shí)例講解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-12-12RabbitMq報(bào)錯reply-code=406 reply-text=PRECONDITION_FAILED
這篇文章主要為大家介紹了RabbitMq報(bào)錯reply-code=406 reply-text=PRECONDITION_FAILED分析解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12SpringBoot集成ffmpeg實(shí)現(xiàn)視頻轉(zhuǎn)碼播放示例詳解
這篇文章主要為大家介紹了SpringBoot集成ffmpeg實(shí)現(xiàn)視頻轉(zhuǎn)碼播放示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07Java數(shù)據(jù)結(jié)構(gòu)之紅黑樹的真正理解
這篇文章主要為大家詳細(xì)介紹了Java數(shù)據(jù)結(jié)構(gòu)之紅黑樹的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-11-11Spring WebFlux使用函數(shù)式編程模型構(gòu)建異步非阻塞服務(wù)
這篇文章主要介紹了Spring WebFlux使用函數(shù)式編程模型構(gòu)建異步非阻塞服務(wù),重點(diǎn)介紹如何使用函數(shù)式編程模型創(chuàng)建響應(yīng)式 RESTful 服務(wù),這種編程模型與傳統(tǒng)的基于 Spring MVC 構(gòu)建 RESTful 服務(wù)的方法有較大差別,感興趣的朋友跟隨小編一起看看吧2023-08-08Java實(shí)現(xiàn)公眾號功能、關(guān)注及消息推送實(shí)例代碼
公眾號開發(fā)近些年是一個比較熱門的方向,下面這篇文章主要給大家介紹了關(guān)于Java實(shí)現(xiàn)公眾號功能、關(guān)注及消息推送的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-11-11Java Map接口及其實(shí)現(xiàn)類原理解析
這篇文章主要介紹了Java Map接口及其實(shí)現(xiàn)類原理解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-03-03