1. 程式人生 > 程式設計 >Kotlin中常見的符號詳解

Kotlin中常見的符號詳解

前幾年的Google I/O大會上,Google正式宣佈,Kotlin將會成為Android開發的官方支援語言。除了Android外,Kotlin還可以完全作為服務端開發的語言,比如在未來的Spring 5就將對Kotlin提供強大的支援。以及瀏覽器程式語言,與JS進行互動。

Kotlin是一門靜態語言,支援多種平臺,包括移動端、服務端以及瀏覽器端,此外,Kotlin還是一門融合了面向物件與函數語言程式設計的語言,支援泛型、安全的空判斷,並且Kotlin與Java可以做到完全的互動。

現在介紹Kotlin的文章已經是鋪天蓋地,大部分都是從Kotlin的基本資料型別介紹起,本文不想重複這樣的事情,這裡從另一面來開始,我們來看看Kotlin中的各種符號。

Kotlin中常見的符號詳解

$符合和多行輸入符

println("itemB:$itemB")

//字串模板
var userInfo = "name:${user.name},age:$age"

//三引號的形式用來輸入多行文字
val str = """ 
  one
  two
    """
//等價於     
val str = "one\ntwo"

三引號之間輸入的內容將被原樣保留,之中的單號和雙引號不轉義,其中的不可見字元比如/n和/t都會被保留。

?問號

表示這個物件可能為空

//在變數型別後面加上問號,代表該變數是可空變數 
var name: String? = "zhangsan" 
/**
 * 如果str不能轉為Int型別,則返回null
 */
fun parseInt(str: String): Int? { 
 // (程式碼略)
}

b?.length //如果 b非空,就返回 b.length ,否則返回 null,這個表示式的型別是 Int? 。

Elvis操作符(?:)

如果r非空,我使用它;否則使⽤某個非空的值 x ”:

val l: Int = if (b != null) b.length else -1

除了完整的 if-表示式,這還可以通過 Elvis 操作符表達:

val l = b?.length ?: -1

如果 ?: 左側表示式非空,elvis操作符就返回其左側表示式,否則返回右側表示式。請注意,當且僅當左側為空時,才會對右側表示式求值。

!! 操作符

對於NPE 愛好者,我們可以寫 b!! ,這會返回一個非空的 b 值 或者如果 b 為空,就會丟擲一個 NPE 異常:

val l = b!!.length

因此,如果你想要一個 NPE,你可以得到它,但是你必須顯式要求它,否則它不會不期而至。

==號與===號

==判斷值是否相等,===判斷值及引用是否完全相等。

val num: Int = 128;
val a:Int? = num
val b:Int? = num
println(a == b)
print(a === b)

..符號

Kotlin中有區間的概念,區間表示式由具有操作符形式 .. 的 rangeTo 函式輔以 in 和 !in 形成。 區間是為任何可比較型別定義的,但對於整型原生型別,它有一個優化的實現。以下是使用區間的一些示例:

if (i in 1..10) { // 等同於 1 <= i && i <= 10
  println(i)
}
//使用until函式,建立一個不包括其結束元素的區間
for (i in 1 until 10) {  // i in [1,10) 排除了 10
   println(i)
}

for (i in 1..4) print(i) // 輸出“1234”

for (i in 4..1) print(i) // 什麼都不輸出

如果你想倒序迭代數字呢?也很簡單。你可以使用標準庫中定義的 downTo() 函式

for (i in 4 downTo 1) print(i) // 輸出“4321”

step()函式,可以指定任意步長

for (i in 1..4 step 2) print(i) // 輸出“13”

for (i in 4 downTo 1 step 2) print(i) // 輸出“42”

_(下劃線)

data class Book(var id: Int,var name: String)

上面的示例中,Book聲明瞭 id,name兩個變數。解構時如果只需要id這一個變數時,可以這麼做:

val book = Book(1,"英語")
val (id,_) = book

::符號

//得到類的Class物件
startActivity(Intent(this@KotlinActivity,MainActivity::class.java))

//行內函數和reified後續介紹
inline fun <reified T> Gson.fromJson(json:String):T
{
  return fromJson(json,T::class.java)
}

方法引用

var setBook = setOf<String>("hello","hi","你好")
//  setBook.forEach { print(it)}
  setBook.forEach(::print)

@符號

1、限定this的型別

class User {
  inner class State{
    fun getUser(): User{
      //返回User
      return this@User
    }
    fun getState(): State{
      //返回State
      return this@State
    }
  }
}

2、作為標籤

跳出雙層for

loop@ for (itemA in arraysA) {
   var i : Int = 0
   for (itemB in arraysB) {
     i++
     if (itemB > 2) {
       break@loop
     }

     println("itemB:$itemB")
   }

}

命名函式自動定義標籤:

fun fun_run(){
  run {
    println("lambda")
  }
  var i: Int = run {
    return@run 1
  }
  println("$i")
  //匿名函式可以通過自定義標籤進行跳轉和返回
  i = run (outer@{
    return@outer 2
  })
  println(i)
}

從forEach函式跳出

fun forEach_label(ints: List<Int>)
{
  var i =2
  ints.forEach {
    //forEach中無法使用continue和break;
//    if (it == 0) continue //編譯錯誤
//    if (it == 2) /*break //編譯錯誤 */
    print(it)
  }
   run outer@{
     ints.forEach {
       if (it == 0) return@forEach //相當於在forEach函式中continue,實際上是從匿名函式返回
       if (it == 2) return@outer //相當於在forEach函式中使用break,實際上是跳轉到outer之外
     }
   }

  if (i == 3)
  {
    //每個函式的名字代表一個函式地址,所以函式自動成為標籤
    return@forEach_label //等同於return
  }
}

{}符號

這裡指的是lambda表示式的符號。

// 一個引數
var callback: ((str: String) -> Unit)? = null
callback = { println(it)}
// 判斷並使用
callback?.invoke("hello")

//兩個引數
var callback2: ((name: String,age: Int) -> Unit)? = null
callback2 = { hello: String,world: Int -> println("$hello's age is $world") }
callback2?.invoke("Tom",22)

var callback3 :((num1:Int,num2: Int)->String)? = null
//型別可以推斷
callback3 = { num1,num2 ->
  var res:Int = num1 + num2
  res.toString()
}

println(callback3?.invoke(1,2))

kotlin中{}裡面整個是lambda的一個表示式,而java8中{}部分只是lambda表示式的body部分。

還要 :符號,用於類名後表示繼承,用於變數後限定變數型別,是Kotlin中最常用的符號,這裡基本囊括了Koltin中一些常見的符號,關於符號就介紹這麼多,如有遺漏請再下方留言提出,我將補充上。

以上這篇Kotlin中常見的符號詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。