Kotlin條件控制語句匯總講解
Tips:Kotlin 中沒有 switch-case。
一、if表達(dá)式
1、帶返回值if表達(dá)式
在 Kotlin 中,if 是一個表達(dá)式所以它會返回一個值,表達(dá)式的值為表達(dá)式作 用域內(nèi)最后一行的值。這一點和 Java 是不同的, 在 Java 中 if 僅僅是語句。
//一般類似 java 中傳統(tǒng) if 的用法 fun maxOf(a: Int, b: Int): Int { if (a > b) { return a } else { return b } } fun main(args: Array<String>) { println(maxOf(1, 5)) } //作為表達(dá)式則可以這樣 fun maxOf(a: Int, b: Int):Int{ return if (a > b) a else b } fun main(args: Array<String>) { println(maxOf(1, 5)) }
if 表達(dá)式分支可以是代碼塊,也可以把作用域內(nèi)最后一行表達(dá)式的值作為該 分支塊的值:
fun maxOf(a: Int, b: Int) = if(a > b) { println(a) a //返回值為 a } else { println(b) b //返回值為 b } fun main(args: Array<String>) { println(maxOf(1, 5)) }
2、if 表達(dá)式替代三目運算符
因為在 Kotlin 中 if 表達(dá)式是帶有返回值的,所以在 Kotlin 中是不需要三目 運算符(xxx ? xxx : xxx), 因為 if 表達(dá)式這些都能做到。
//Java 中三目運算符 public int maxOf(int a, int b) { return a > b ? a : b; }
而在 Kotlin 中則可以直接使用 if 表達(dá)式來使用:
//Kotlin 中的 if 表達(dá)式 fun maxOf(a: Int, b: Int) = if (a > b) a else b
Tips:如果你使用 if 作為表達(dá)式而不是語句(例如:返回它的值或者把它賦 給變量),該表達(dá)式需要有 else 分支。
3、多級if表達(dá)式
和 Java 一樣 Kotlin 也支持 if-else if-else 等多級條件選擇,但是一般如 果這種帶多級條件選擇的 IDE 會提示你使用 when 表達(dá)式來替代: 下面這個案例會使用 if-else if-else 來判斷變量 number 是何種數(shù)據(jù)類型:
fun eval(number: Number) { if (number is Int) { println("this is int number") } else if (number is Double) { prinln("this is double number") } else if (number is Float) { println("this is float number") } else if (number is Long) { println("this is long number") } else if (number is Byte) { println("this is byte number") } else if (number is Short) { println("this is Short number") } else { throw IllegalArgumentException("invalid argument") } }
但是需要注意的是 如果 eval 函數(shù)需要有返回值的時候,必須要有 else 分支。
二、When表達(dá)式
在 Kotlin 中使用 when 表達(dá)式替代了類似 C 語言的 switch-case 語句。其中 最簡單的形式如下:
fun eval(number: Number): String = when (number) { is Int -> "this is int number" is Double -> "this is double number" is Float -> "ths is float number" is Long -> "this is long number" is Byte -> "this is byte number" is Short -> "this is Short number" else -> "invalid number" } //多種條件判斷混合形式 fun main(args: Array<String>) { println(descript("hello")) } fun descript(obj: Any): String = when (obj) { 1 -> "one" "hello" -> "hello word" is Long -> "long type" !is String -> "is not String" else -> { "unknown type" } }
when 將它的參數(shù)與所有的分支條件順序比較,直到某個分支滿足條 件。 when 既可以被當(dāng)做表達(dá)式使用也可以被當(dāng)做語句使用。如果它被當(dāng)做 表達(dá)式, 符合條件的分支的值就是整個表達(dá)式的值,如果當(dāng)做語句使用, 則忽略個別分支的值。(像 if 一樣,每一個分支可以是一個代碼塊,它的值 是塊中最后的表達(dá)式的值。)
Tips:如果其他分支都不滿足條件將會求值 else 分支。 如果 when 作為一 個表達(dá)式使用,則必須有 else 分支, 除非編譯器能夠檢測出所有的可能情 況都已經(jīng)覆蓋了。
如果很多分支需要用相同的方式處理,則可以把多個分支條件放在一起,用 逗號分隔:
fun eval(any: Any): String = when (any) { is Int, Double, Float, Long, Byte, Short -> "this is number" //多個分 支條件放在一起,用逗號分隔 is Char -> "this is char" else -> "other" }
when 也可以用來取代 if-else if 鏈。 如果不提供參數(shù),所有的分支條件都是 簡單的布爾表達(dá)式,而當(dāng)一個分支的條件為真時則執(zhí)行該分支:
fun eval(number: Number) { when { number.isOdd() -> { println("this is odd number") } number.isEven() -> { println("this is even number") } else -> println("this is invalid number") } }
三、when 表達(dá)式的功能增強
自從 Kotlin1.3 版本后對 when 表達(dá)式做了一個寫法上的優(yōu)化,為什么這么 說呢? 僅僅就是寫法上的優(yōu)化,實際上什么都沒做. 它主要是解決什么問題 呢?細(xì)心的小伙伴會發(fā)現(xiàn),在 Kotlin 1.3 版本之前 when 表達(dá)式內(nèi)部是不能使 用傳入的值的。
1、Kotlin 1.3 版本之前 when
fun main(args: Array<String>) { val value = getValue() //可以看到 1.3 版本之前需要多出來一步 when (value) { is Int -> "This is Int Type, value is $value".apply(::println) // 注意這里 when 中獲得 value 不是 when 直接傳入 value,而是 when 外部聲明 value is String -> "This is String Type, value is $value".apply(::println) is Double -> "This is Double Type, value is $value".apply(::println) is Float -> "This is Float Type, value is $value".apply(::println) else -> "unknown type".apply(::println) } } fun getValue(): Any { return 100F }
我們可以嘗試把 kotlin 1.3 版本之前 when 表達(dá)式使用代碼反編譯成 Java 代碼:
public static final void main(@NotNull String[] args) { Intrinsics.checkParameterIsNotNull(args, "args"); Object value = getValue(); String var3; if (value instanceof Integer) { var3 = "This is Int Type, value is " + value; System.out.println(var3); } else if (value instanceof String) { var3 = "This is String Type, value is " + value; System.out.println(var3); } else if (value instanceof Double) { var3 = "This is Double Type, value is " + value; System.out.println(var3); } else if (value instanceof Float) { var3 = "This is Float Type, value is " + value; System.out.println(var3); } else { var3 = "unknown type"; System.out.println(var3); } } @NotNull public static final Object getValue() { return 100.0F; }
2、Kotlin 1.3 版本之后 when
fun main(args: Array<String>) { when (val value = getValue()) {//when 表達(dá)式條件直接是一個表達(dá)式,并用 value 保存了返回值, 實際上相當(dāng)于把外部那一行縮進來寫 is Int -> "This is Int Type, value is $value".apply(::println) is String -> "This is String Type, value is $value".apply(::println) is Double -> "This is Double Type, value is $value".apply(::println) is Float -> "This is Float Type, value is $value".apply(::println) else -> "unknown type".apply(::println) } } fun getValue(): Any { return 100F }
通過對比發(fā)現(xiàn),Kotlin 1.3 前后 when 表達(dá)式的增強,僅僅是把原來外部那一行代碼,縮 進到 when 里寫,然而兩次寫法反編譯的 Java 代碼是一致的。
四、使用 when 表達(dá)式替代 if 表達(dá)式
和 if 表達(dá)式一樣,when 表達(dá)式也是帶有返回值的。建議對于多層條件級或嵌 套條件控制的使用建議使用 when 替代 if-else:
fun eval(number: Number) { if (number is Int) { println("this is int number") } else if (number is Double) { println("this is double number") } else if (number is Float) { println("this is float number") } else if (number is Long) { println("this is long number") } else if (number is Byte) { println("this is byte number") } else if (number is Short) { println("this is Short number") } else { throw IllegalArgumentException("invalid argument") } } //多層級條件使用 when 表達(dá)式 fun eval(number: Number): String = when (number) { is Int -> "this is int number" is Double -> "this is double number" is Float -> "ths is float number" is Long -> "this is long number" is Byte -> "this is byte number" is Short -> "this is Short number" else -> "invalid number" }
總結(jié)
到這里 Kotlin 中的條件控制就闡述完畢了,可以發(fā)現(xiàn) Kotlin 中條件控制和 Java 還是存在著很多的不一樣的,需要多多練習(xí)多多理解,下一篇我們將進 入 Kotlin 中循環(huán)控制。
到此這篇關(guān)于Kotlin條件控制語句匯總講解的文章就介紹到這了,更多相關(guān)Kotlin條件控制內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android編程實現(xiàn)RotateAnimation設(shè)置中心點旋轉(zhuǎn)動畫效果
這篇文章主要介紹了Android編程實現(xiàn)RotateAnimation設(shè)置中心點旋轉(zhuǎn)動畫效果,結(jié)合實例形式較為詳細(xì)的分析了Android xml布局及RotateAnimation動畫類相關(guān)操作技巧,需要的朋友可以參考下2018-02-02Android編程調(diào)用系統(tǒng)自帶的拍照功能并返回JPG文件示例【附demo源碼下載】
這篇文章主要介紹了Android編程調(diào)用系統(tǒng)自帶的拍照功能并返回JPG文件,結(jié)合實例形式分析了Android的拍照功能調(diào)用及圖形文件操作技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2017-07-07解析Android開發(fā)優(yōu)化之:對界面UI的優(yōu)化詳解(一)
在Android應(yīng)用開發(fā)過程中,屏幕上控件的布局代碼和程序的邏輯代碼通常是分開的。界面的布局代碼是放在一個獨立的xml文件中的,這個文件里面是樹型組織的,控制著頁面的布局2013-05-05Android Studio中導(dǎo)入JNI生成的.so庫的實現(xiàn)方法
這篇文章主要介紹了Android Studio中導(dǎo)入JNI生成的.so庫的實現(xiàn)方法的相關(guān)資料,這里不僅提供實現(xiàn)方案并提供了實現(xiàn)的方法,需要的朋友可以參考下2017-07-07Android Jetpack架構(gòu)組件Lifecycle詳解
這篇文章主要介紹了Android Jetpack架構(gòu)組件Lifecycle詳解,Lifecycle是Jetpack架構(gòu)組件中用來感知生命周期的組件,使用Lifecycles可以幫助我們寫出和生命周期相關(guān)更簡潔更易維護的代碼。對此感興趣的小伙伴可以來學(xué)習(xí)一下2020-07-07Android調(diào)用系統(tǒng)自帶的分享功能實例代碼
本篇文章主要介紹了Android調(diào)用系統(tǒng)自帶的分享功能實例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下。2017-04-04