1. 程式人生 > >小白成長記(四)—— Kotlin基礎資料型別

小白成長記(四)—— Kotlin基礎資料型別

Kotlin 的基本數值型別包括 Byte、Short、Int、Long、Float、Double 等。不同於Java的是,字元不屬於數值型別,是一個獨立的資料型別。

 一.常量

  • 十進位制:123
  • 長整型以大寫的 L 結尾:123L
  • 16 進位制以 0x 開頭:0x0F
  • 2 進位制以 0b 開頭:0b00001011
  • 注意:8進位制不支援

Kotlin 同時也支援傳統符號表示的浮點數值:

  • Doubles 預設寫法: 123.5123.5e10
  • Floats 使用 f 或者 F 字尾:123.5f

二.比較兩個數字

Kotlin 中沒有基礎資料型別,只有封裝的數字型別,你每定義的一個變數,其實 Kotlin 幫你封裝了一個物件,這樣可以保證不會出現空指標。數字型別也一樣,所有在比較兩個數字的時候,就有比較資料大小和比較兩個物件是否相同的區別了。在 Kotlin 中,三個等號 === 表示比較物件地址,兩個 == 表示比較兩個值大小。

fun main(args: Array<String>) {
    val a: Int = 10000
    println(a === a) // true,值相等,物件地址相等

    //經過了裝箱,建立了兩個不同的物件
    val boxedA: Int? = a
    val anotherBoxedA: Int? = a

    //雖然經過了裝箱,但是值是相等的,都是10000
    println(boxedA === anotherBoxedA) //  false,值相等,物件地址不一樣
    println(boxedA == anotherBoxedA) // true,值相等
}

三.型別轉換

由於不同的表示方式,較小型別並不是較大型別的子型別,較小的型別不能隱式轉換為較大的型別。 這意味著在不進行顯式轉換的情況下我們不能把 Byte 型值賦給一個 Int 變數。

val b: Byte = 1 // OK, 字面值是靜態檢測的
val i: Int = b // 錯誤

//我們可以代用其toInt()方法

val b: Byte = 1 // OK, 字面值是靜態檢測的
val i: Int = b.toInt() // OK

每種資料型別都有下面的這些方法,可以轉化為其它的型別:toByte():Byte   

toShort(): Short   /  toInt(): Int  /    toLong(): Long  /  toFloat():Float     /    toDouble(): Double  / toChar(): Char

四.位操作符

對於Int和Long型別,還有一系列的位操作符可以使用,分別是:

shl(bits) – 左移位 (Java’s <<)
shr(bits) – 右移位 (Java’s >>)
ushr(bits) – 無符號右移位 (Java’s >>>)
and(bits) – 與
or(bits) – 或
xor(bits) – 異或
inv() – 反向

五.字元

和 Java 不一樣,Kotlin 中的 Char 不能直接和數字操作,Char 必需是單引號 ' 包含起來的。比如普通字元 '0','a'。

fun check(c: Char) {
    if (c == 1) { // 錯誤:型別不相容
        // ……
    }
}
 //字元字面值用單引號括起來: '1'。 特殊字元可以用反斜槓轉義。 支援這幾個轉義序列:\t、 \b、\n、
  //  \r、\'、\"、\\ 和 \$。 編碼其他字元要用 Unicode 轉義序列語法:'\uFF00'。

// 我們可以顯式把字元轉換為 Int 數字:

fun decimalDigitValue(c: Char): Int {
    if (c !in '0'..'9')
        throw IllegalArgumentException("Out of range")
    return c.toInt() - '0'.toInt() // 顯式轉換為數字
}

當需要可空引用時,像數字、字元會被裝箱。裝箱操作不會保留同一性。 

六.陣列

陣列用類 Array 實現,並且還有一個 size 屬性及 get 和 set 方法,由於使用 [] 過載了 get 和 set 方法,所以我們可以通過下標很方便的獲取或者設定陣列對應位置的值。

陣列的建立兩種方式:一種是使用函式arrayOf();另外一種是使用工廠函式。如下所示,我們分別是兩種方式建立了兩個陣列:

fun main(args: Array<String>) {
    //[1,2,3]
    val a = arrayOf(1, 2, 3)
    //[0,2,4]
    val b = Array(3, { i -> (i * 2) })

    //讀取陣列內容
    println(a[0])    // 輸出結果:1
    println(b[1])    // 輸出結果:2
}

如上所述,[] 運算子代表呼叫成員函式 get() 和 set()。

注意: 與 Java 不同的是,Kotlin 中陣列是不型變的(invariant)。

除了類Array,還有ByteArray, ShortArray, IntArray,用來表示各個型別的陣列,省去了裝箱操作,因此效率更高,其用法同Array一樣:

val x: IntArray = intArrayOf(1, 2, 3)
x[0] = x[1] + x[2]

 七.字串

 和 Java 一樣,String 是不可變的。方括號 [] 語法可以很方便的獲取字串中的某個字元,也可以通過 for 迴圈來遍歷,Kotlin 支援三個引號 """ 擴起來的字串,支援多行字串,String 可以通過 trimMargin() 方法來刪除多餘的空白。

// 1.遍歷
for (c in str) {
    println(c)
}

//2.多行字串
fun main(args: Array<String>) {
    val text = """
    多行字串
    多行字串
    """
    println(text)   // 輸出有一些前置空格
}

//3.trimMargin() 方法來刪除多餘的空白。
fun main(args: Array<String>) {
    val text = """
    |多行字串
    |菜鳥教程
    |多行字串
    |Runoob
    """.trimMargin()
    println(text)    // 前置空格刪除了
}