??Kotlin是JVM和Android的實(shí)用編程語(yǔ)言,結(jié)合了OO和功能特性,專注于互操作性,安全性,清晰度和工具支持。
??作為通用語(yǔ)言,Kotlin可以在Java工作的地方工作:服務(wù)器端應(yīng)用程序,移動(dòng)應(yīng)用程序(Android),桌面應(yīng)用程序。它適用于所有主要的工具和服務(wù)。
??Kotlin的關(guān)鍵重點(diǎn)之一是混合Java + Kotlin項(xiàng)目的互操作性和無(wú)縫支持,使采用更容易,從而減少了樣板代碼和更多的類型安全性。此外,Kotlin有一個(gè)廣泛的標(biāo)準(zhǔn)庫(kù),使日常任務(wù)輕松流暢,同時(shí)保持字節(jié)碼足跡低。當(dāng)然,也可以在Kotlin中使用任何Java庫(kù)。反之亦然。
??下面是Kotlin的幾個(gè)具體優(yōu)勢(shì):
1.與Java的互通性
??Kotlin能夠達(dá)到和JAVA的100%互通,也就是說你可以使用Kotlin開發(fā)您的舊的JAVA項(xiàng)目,所有的你喜歡的Java框架都可以繼續(xù)使用,而且你寫的一些Kotlin的框架也都能非常容易的服務(wù)于你的java朋友愛好者。
2.字符串差值
??就好像內(nèi)置了一個(gè)更智能、更易讀的Java版本的String.format()。
val x = 4
val y = 7
print("sum of $x and $y is ${x + y}") // sum of 4 and 7 is 11
3.類型推斷
??Kotlin會(huì)推斷你的想要的類型(你將會(huì)覺得提高代碼的閱讀性)
val a = "abc" // type inferred to
Stringval b = 4 // type inferred
to Int val c: Double = 0.7 // type declared explicitly
val d: List<String> = ArrayList() // type declared explicitly
4.聰明的類型轉(zhuǎn)換
??Kotlin編譯器會(huì)跟蹤您的邏輯做自動(dòng)轉(zhuǎn)換類型,這意味著不會(huì)有過多的instanceof檢測(cè)(在明確的轉(zhuǎn)換)
if (obj is String) {
print(obj.toUpperCase()) // obj is now known to be a String
}
5.直觀上的相等
??你可以停止使用equals()方法來(lái)判斷相等,因?yàn)?=這個(gè)操作符將會(huì)檢測(cè)結(jié)構(gòu)相等性。
val john1 = Person("John")
val john2 = Person("John")
john1 == john2 // true (structural equality)
john1 === john2 // false (referential equality)
6.默認(rèn)參數(shù)
??不需要定義幾個(gè)相似參數(shù)的方法
fun build(title: String, width: Int = 800, height: Int = 600) {
Frame(title, width, height)
}
7.命名參數(shù)
??結(jié)合默認(rèn)參數(shù),命名參數(shù)消除了構(gòu)造者。
build("PacMan", 400, 300) // equivalent
build(title = "PacMan", width = 400, height = 300) // equivalent
build(width = 400, height = 300, title = "PacMan") // equivalent
8.when表達(dá)式
??switch語(yǔ)句被替換成更加易讀和靈活的when表達(dá)式
when (x) {
1 -> print("x is 1")
2 -> print("x is 2")
3, 4 -> print("x is 3 or 4")
in 5..10 -> print("x is 5, 6, 7, 8, 9, or 10")
else -> print("x is out of range")
}
??既可以作為一個(gè)表達(dá)式或者一個(gè)語(yǔ)句,也可以有參數(shù)或者沒有參數(shù)
val res: Boolean = when {
obj == null -> false
obj is String -> true
else -> throw IllegalStateException()
}
9.屬性
??公開的(非私有的)參數(shù)自定義的set&get行為,這意味著可以阻止我們的代碼膨脹(getters&setters帶來(lái)的)
class Frame {
var width: Int = 800
var height: Int = 600
val pixels: Int
get() = width * height
}
10.范圍(Ranges)
??方便可讀性
for (i in 1..100) { ... }
for (i in 0 until 100) { ... }
for (i in 2..10 step 2) { ... }
for (i in 10 downTo 1) { ... }
if (x in 1..10) { ... }
11.擴(kuò)展方法/功能
??是否還記得第一次使用Java中List的排序么?你找不到一個(gè)sort方法進(jìn)行排序從而你不得不咨詢你的老師或者查找google來(lái)獲取到Collections.sort()這個(gè)方法.后來(lái)當(dāng)你使用一個(gè)String的時(shí)候可能你會(huì)寫一個(gè)幫助類來(lái)幫助你達(dá)到想要的目的,因?yàn)槟悴恢烙蠸tringUtils.capitalize()。
??如果只有一種方法可以向舊類添加新功能,這樣你的IDE將會(huì)幫助你在代碼中找到相應(yīng)的功能,這一點(diǎn)在Kotlin上面很容易實(shí)現(xiàn)。
fun String.format(): String {
return this.replace(' ', '_')
}
val formatted = str.format()
??標(biāo)準(zhǔn)庫(kù)擴(kuò)展了Java的原始類型的功能,這正是String特別需要的:
str.removeSuffix(".txt")
str.capitalize()
str.substringAfterLast("/")
str.replaceAfter(":", "classified")
12.空值安全
??Java是一種應(yīng)該稱之為幾乎靜態(tài)類型的語(yǔ)言,在Java中,String類型的變量不能保證引用String(安全),它可能引用為null,即使我們已經(jīng)習(xí)慣了這個(gè)類型,它抵消了靜態(tài)類型檢查的安全性,所以Java開發(fā)人員將不可避免的遇見NPEs(NullPointerException)或者想法設(shè)法的避免(有點(diǎn)多于的工作)。
??Kotlin則是通過區(qū)分非空類型和空類型來(lái)解決這個(gè)問題。默認(rèn)情況下,類型為非空,并且可以默認(rèn)添加一個(gè)"?"例如以下這樣:
var a: String = "abc"
a = null // 編譯報(bào)錯(cuò),a不能為null
var b: String? = "xyz"
b = null // b可以為null,編譯通過
??當(dāng)你訪問一個(gè)空的變量的時(shí)候,Kotlin會(huì)強(qiáng)制的避免NPES(NullPointerException)
val x = b.length // compile error: b might be null
??雖然這個(gè)看起來(lái)有點(diǎn)繁瑣,但是因?yàn)樗倪@些功能真的可以是開發(fā)輕松起來(lái),并且我們可以智能的轉(zhuǎn)換,將空的類型轉(zhuǎn)換為非空類型供我們使用.
if (b == null) returnval x = b.length // no problem
??并且我們可以安全的使用,當(dāng)我們計(jì)算的為空的時(shí)候(而不是拋出空指針異常)
val x = b?.length // type of x is nullable Int
??安全調(diào)用可以鏈接在一起,以避免我們有時(shí)用其他語(yǔ)言編寫的嵌套的if-not-null檢查,如果我們想要一個(gè)非null之外的默認(rèn)值,我們可以使用elvis操作符
val name = ship?.captain?.name ?: "unknown"
??如果這樣并不適用于你,而且你需要一個(gè)NPE,你將不得不明確地要求它
val x = b?.length ?: throw NullPointerException() // same as below
val x = b!!.length // same as above
13.更好的Lambda表達(dá)式
??Kotlin更好的支持Lambda,基于他的聰明良好的語(yǔ)言設(shè)計(jì),語(yǔ)法直接了當(dāng),可讀性和簡(jiǎn)潔性更好。
val sum = { x: Int, y: Int -> x + y } // type: (Int, Int) -> Int
val res = sum(4,7) // res == 11
??更好的說明以下
- 如果lambda表達(dá)式是方法的最后一個(gè)參數(shù)或唯一的參數(shù),則可以移動(dòng)或省略方法括號(hào);
- 如果我們選擇不聲明一個(gè)single-argument-lambda,它將被隱式聲明為it
??由以上兩點(diǎn)可以得到以下三行代碼形式:
numbers.filter({ x -> x.isPrime() })
numbers.filter { x -> x.isPrime() }
numbers.filter { it.isPrime() }
??而且這也允許我們寫出更加簡(jiǎn)潔漂亮的代碼:
persons
.filter { it.age >= 18 }
.sortedBy { it.name }
.map { it.email }
.forEach { print(it) }
??Kotlin的lambda系統(tǒng)功能的完美結(jié)合使其成為DSL創(chuàng)建的理想選擇,查看Anko的DSL示例,旨在服務(wù)Android開發(fā)。
verticalLayout {
padding = dip(30)
editText {
hint = “Name”
textSize = 24f
}
editText {
hint = “Password”
textSize = 24f
}
button(“Login”) {
textSize = 26f
}
}
??如果你有疑問或更好的算法思路,歡迎留言交流!!!
??如果感覺我的文章對(duì)您有所幫助,麻煩動(dòng)動(dòng)小手給個(gè)喜歡,謝謝?。?!