Kotlin 的基本數(shù)值類型包括 Byte、Short、Int、Long、Float、Double 等。不同于 Java 的是,字符不屬于數(shù)值類型,是一個獨立的數(shù)據(jù)類型。
類型 | 位寬度 |
---|---|
Double | 64 |
Float | 32 |
Long | 64 |
Int | 32 |
Short | 16 |
Byte | 8 |
下面是所有類型的字面常量:
Kotlin 同時也支持傳統(tǒng)符號表示的浮點數(shù)值:
你可以使用下劃線使數(shù)字常量更易讀:
val oneMillion = 1_000_000
val creditCardNumber = 1234_5678_9012_3456L
val socialSecurityNumber = 999_99_9999L
val hexBytes = 0xFF_EC_DE_5E
val bytes = 0b11010010_01101001_10010100_10010010
Kotlin 中沒有基礎數(shù)據(jù)類型,只有封裝的數(shù)字類型,你每定義的一個變量,其實 Kotlin 幫你封裝了一個對象,這樣可以保證不會出現(xiàn)空指針。數(shù)字類型也一樣,所以在比較兩個數(shù)字的時候,就有比較數(shù)據(jù)大小和比較兩個對象是否相同的區(qū)別了。
在 Kotlin 中,三個等號 === 表示比較對象地址,兩個 == 表示比較兩個值大小。
fun main(args: Array<String>) {
val a: Int = 10000
println(a === a) // true,值相等,對象地址相等
//經(jīng)過了裝箱,創(chuàng)建了兩個不同的對象
val boxedA: Int? = a
val anotherBoxedA: Int? = a
//雖然經(jīng)過了裝箱,但是值是相等的,都是10000
println(boxedA === anotherBoxedA) // false,值相等,對象地址不一樣
println(boxedA == anotherBoxedA) // true,值相等
}
由于不同的表示方式,較小類型并不是較大類型的子類型,較小的類型不能隱式轉(zhuǎn)換為較大的類型。 這意味著在不進行顯式轉(zhuǎn)換的情況下我們不能把 Byte 型值賦給一個 Int 變量。
val b: Byte = 1 // OK, 字面值是靜態(tài)檢測的
val i: Int = b // 錯誤
我們可以代用其toInt()方法。
val b: Byte = 1 // OK, 字面值是靜態(tài)檢測的
val i: Int = b.toInt() // OK
每種數(shù)據(jù)類型都有下面的這些方法,可以轉(zhuǎn)化為其它的類型:
toByte(): Byte
toShort(): Short
toInt(): Int
toLong(): Long
toFloat(): Float
toDouble(): Double
toChar(): Char
有些情況下也是可以使用自動類型轉(zhuǎn)化的,前提是可以根據(jù)上下文環(huán)境推斷出正確的數(shù)據(jù)類型而且數(shù)學操作符會做相應的重載。例如下面是正確的:
val l = 1L + 3 // Long + Int => Long
對于Int和Long類型,還有一系列的位操作符可以使用,分別是:
shl(bits) – 左移位 (Java’s <<)
shr(bits) – 右移位 (Java’s >>)
ushr(bits) – 無符號右移位 (Java’s >>>)
and(bits) – 與
or(bits) – 或
xor(bits) – 異或
inv() – 反向
和 Java 不一樣,Kotlin 中的 Char 不能直接和數(shù)字操作,Char 必需是單引號 ' 包含起來的。比如普通字符 '0','a'。
fun check(c: Char) {
if (c == 1) { // 錯誤:類型不兼容
// ……
}
}
字符字面值用單引號括起來: '1'。 特殊字符可以用反斜杠轉(zhuǎn)義。 支持這幾個轉(zhuǎn)義序列:\t、 \b、\n、\r、\'、\"、\\ 和 \$。 編碼其他字符要用 Unicode 轉(zhuǎn)義序列語法:'\uFF00'。
我們可以顯式把字符轉(zhuǎn)換為 Int 數(shù)字:
fun decimalDigitValue(c: Char): Int {
if (c !in '0'..'9')
throw IllegalArgumentException("Out of range")
return c.toInt() - '0'.toInt() // 顯式轉(zhuǎn)換為數(shù)字
}
當需要可空引用時,像數(shù)字、字符會被裝箱。裝箱操作不會保留同一性。
布爾用 Boolean 類型表示,它有兩個值:true 和 false。
若需要可空引用布爾會被裝箱。
內(nèi)置的布爾運算有:
|| – 短路邏輯或
&& – 短路邏輯與
! - 邏輯非
數(shù)組用類 Array 實現(xiàn),并且還有一個 size 屬性及 get 和 set 方法,由于使用 [] 重載了 get 和 set 方法,所以我們可以通過下標很方便的獲取或者設置數(shù)組對應位置的值。
數(shù)組的創(chuàng)建兩種方式:一種是使用函數(shù)arrayOf();另外一種是使用工廠函數(shù)。如下所示,我們分別是兩種方式創(chuàng)建了兩個數(shù)組:
fun main(args: Array<String>) {
//[1,2,3]
val a = arrayOf(1, 2, 3)
//[0,2,4]
val b = Array(3, { i -> (i * 2) })
//讀取數(shù)組內(nèi)容
println(a[0]) // 輸出結果:1
println(b[1]) // 輸出結果:2
}
如上所述,[] 運算符代表調(diào)用成員函數(shù) get() 和 set()。
注意: 與 Java 不同的是,Kotlin 中數(shù)組是不型變的(invariant)。
除了類Array,還有ByteArray, ShortArray, IntArray,用來表示各個類型的數(shù)組,省去了裝箱操作,因此效率更高,其用法同Array一樣:
val x: IntArray = intArrayOf(1, 2, 3)
x[0] = x[1] + x[2]
和 Java 一樣,String 是不可變的。方括號 [] 語法可以很方便的獲取字符串中的某個字符,也可以通過 for 循環(huán)來遍歷:
for (c in str) {
println(c)
}
Kotlin 支持三個引號 """ 擴起來的字符串,支持多行字符串,比如:
fun main(args: Array<String>) {
val text = """
多行字符串
多行字符串
"""
println(text) // 輸出有一些前置空格
}
String 可以通過 trimMargin() 方法來刪除多余的空白。
fun main(args: Array<String>) {
val text = """
|多行字符串
|編程獅
|多行字符串
|W3cschool
""".trimMargin()
println(text) // 前置空格刪除了
}
默認 | 用作邊界前綴,但你可以選擇其他字符并作為參數(shù)傳入,比如 trimMargin(">")。
字符串可以包含模板表達式 ,即一些小段代碼,會求值并把結果合并到字符串中。 模板表達式以美元符($)開頭,由一個簡單的名字構成:
fun main(args: Array<String>) {
val i = 10
val s = "i = $i" // 求值結果為 "i = 10"
println(s)
}
或者用花括號擴起來的任意表達式:
fun main(args: Array<String>) {
val s = "w3cschool"
val str = "$s.length is ${s.length}" // 求值結果為 "w3cschool.length is 6"
println(str)
}
原生字符串和轉(zhuǎn)義字符串內(nèi)部都支持模板。 如果你需要在原生字符串中表示字面值 $ 字符(它不支持反斜杠轉(zhuǎn)義),你可以用下列語法:
fun main(args: Array<String>) {
val price = """
${'$'}9.99
"""
println(price) // 求值結果為 $9.99
}
更多建議: