日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
快速入門Kotlin的11招

最近經(jīng)常會(huì)收到一些 “用 Kotlin 怎么寫” 的問(wèn)題,作為有經(jīng)驗(yàn)的程序員,我們已經(jīng)掌握了一門或者多門語(yǔ)言,那么學(xué) Kotlin 的時(shí)候就經(jīng)常會(huì)有類似 “ ‘再見’用日語(yǔ)怎么說(shuō)?”、“ ‘你好’ 用西班牙語(yǔ)怎么說(shuō)?” 的問(wèn)題,所以我決定把一些常用的語(yǔ)法對(duì)照列舉出來(lái),如果大家熟悉 Java,那么快速上手 Kotlin 會(huì)變得非常地容易。

創(chuàng)新互聯(lián)公司是一家以網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)、品牌設(shè)計(jì)、軟件運(yùn)維、seo優(yōu)化、小程序App開發(fā)等移動(dòng)開發(fā)為一體互聯(lián)網(wǎng)公司。已累計(jì)為成都LED顯示屏等眾行業(yè)中小客戶提供優(yōu)質(zhì)的互聯(lián)網(wǎng)建站和軟件開發(fā)服務(wù)。

這篇文章主要是寫給需要快速上手 Kotlin 的 Java 程序員看的,這時(shí)候他們關(guān)注的是如何 Kotlin 寫出類似某些 Java 的寫法,所以本文基本不涉及 Kotlin 的高級(jí)特性。

1. 如何定義變量

Java 定義變量的寫法:

 
 
 
 
  1. String string = "Hello";

基本等價(jià)的 Kotlin 定義變量的寫法:

 
 
 
 
  1. var string: String = "Hello"

Java 定義 final 變量的寫法:

 
 
 
 
  1. final String string = "Hello";

注意到前面的是一個(gè)編譯期常量,Kotlin 當(dāng)中應(yīng)該這么寫:

 
 
 
 
  1. const val string: String = "Hello"

同樣是 final 變量,Java 這么寫:

 
 
 
 
  1. final String string = getString();

注意到,這個(gè)不是編譯期常量,Kotlin 這么寫:

 
 
 
 
  1. val string: String = getString()

另外, Kotlin 有類型推導(dǎo)的特性,因此上述變量定義基本上都可以省略掉類型 String。

2. 如何定義函數(shù)

Java 當(dāng)中如何定義函數(shù),也就是方法,需要定義到一個(gè)類當(dāng)中:

 
 
 
 
  1. public boolean testString(String name){ 
  2. ... 
  3. }

等價(jià)的 Kotlin 寫法:

 
 
 
 
  1. fun testString(name: String): Boolean {
  2.     ...
  3. }

注意到返回值的位置放到了參數(shù)之后。

3. 如何定義靜態(tài)變量、方法

Java 的靜態(tài)方法或者變量只需要加一個(gè) static 即可:

 
 
 
 
  1. public class Singleton{
  2.     private static Singleton instance = ...;
  3.     public static Singleton getInstance(){
  4.         ...
  5.         return instance;
  6.     }
  7. }

用 Kotlin 直譯過(guò)來(lái)就是:

 
 
 
 
  1. class KotlinSingleton{
  2.     companion object{
  3.         private val kotlinSingleton = KotlinSingleton()
  4.         @JvmStatic
  5.         fun getInstance() = kotlinSingleton
  6.     }
  7. }

注意 getInstance 的寫法。 JvmStatic 這個(gè)注解會(huì)將 getInstance 這個(gè)方法編譯成與 Java 的靜態(tài)方法一樣的簽名,如果不加這個(gè)注解,Java 當(dāng)中無(wú)法像調(diào)用 Java 靜態(tài)方法那樣調(diào)用這個(gè)方法。

另外,對(duì)于靜態(tài)方法、變量的場(chǎng)景,在 Kotlin 當(dāng)中建議使用包級(jí)函數(shù)。

4. 如何定義數(shù)組

Java 的數(shù)組非常簡(jiǎn)單,當(dāng)然也有些抽象,畢竟是編譯期生成的類:

 
 
 
 
  1. String[] names = new String[]{"Kyo", "Ryu", "Iory"}; 
  2. String[] emptyStrings = new String[10];

Kotlin 的數(shù)組其實(shí)更真實(shí)一些,看上去更讓人容易理解:

 
 
 
 
  1. val names: Array = arrayOf("Kyo", "Ryu", "Iory")
  2. val emptyStrings: Array = arrayOfNulls(10)

注意到,Array T 即數(shù)組元素的類型。另外,String? 表示可以為 null 的 String 類型。

數(shù)組的使用基本一致。需要注意的是,為了避免裝箱和拆箱的開銷,Kotlin 對(duì)基本類型包括 Int、Short、Byte、Long、Float、Double、Char 等基本類型提供了定制版數(shù)組類型,寫法為 XArray,例如 Int 的定制版數(shù)組為 IntArray,如果我們要定義一個(gè)整型數(shù)組,寫法如下:

 
 
 
 
  1. val ints = intArrayOf(1, 3, 5)

5. 如何寫變長(zhǎng)參數(shù)

Java 的變長(zhǎng)參數(shù)寫法如下:

 
 
 
 
  1. void hello(String... names){
  2.     ...
  3. }

Kotlin 的變長(zhǎng)參數(shù)寫法如下:

 
 
 
 
  1. fun hello(vararg names: String){ 
  2. }

6. 如何寫三元運(yùn)算符

Java 可以寫三元運(yùn)算符:

 
 
 
 
  1. int code = isSuccessfully? 200: 400;

很多人抱怨 Kotlin 為什么沒有這個(gè)運(yùn)算符。。。據(jù)說(shuō)是因?yàn)?Kotlin 當(dāng)中 : 使用的場(chǎng)景比 Java 復(fù)雜得多,因此如果加上這個(gè)三元運(yùn)算符的話,會(huì)給語(yǔ)法解析器帶來(lái)較多的麻煩,Scala 也是類似的情況。那么這中情況下,我們用 Kotlin 該怎么寫呢?

 
 
 
 
  1. int code = if(isSuccessfully) 200 else 400

注意到,if else 這樣的語(yǔ)句也是表達(dá)式,這一點(diǎn)與 Java 不同。

7. 如何寫 main 函數(shù)

Java 的寫法只有一種:

 
 
 
 
  1. class Main{
  2.     public static void main(String... args){
  3.         ...
  4.     }
  5. }

注意到參數(shù)可以是變長(zhǎng)參數(shù)或者數(shù)組,這二者都可。

對(duì)應(yīng) Kotlin,main 函數(shù)的寫法如下:

 
 
 
 
  1. class KotlinMain{
  2.     companion object{
  3.         @JvmStatic
  4.         fun main(args: Array) {
  5.         }
  6.     }
  7. }

Kotlin 可以有包級(jí)函數(shù),因此我們并不需要聲明一個(gè)類來(lái)包裝 main 函數(shù):

 
 
 
 
  1. fun main(args: Array){
  2.     ...
  3. }

8. 如何實(shí)例化類

Java 和 C++ 這樣的語(yǔ)言,在構(gòu)造對(duì)象的時(shí)候經(jīng)常需要用到 new 這個(gè)關(guān)鍵字,比如:

 
 
 
 
  1. Date date = new Date();

Kotlin 構(gòu)造對(duì)象時(shí),不需要 new 這個(gè)關(guān)鍵字,所以上述寫法等價(jià)于:

 
 
 
 
  1. val date = Date()

9. 如何寫 Getter 和 Setter 方法

Java 的 Getter 和 Setter 是一種約定俗稱,而不是語(yǔ)法特性,所以定義起來(lái)相對(duì)自由:

 
 
 
 
  1. public class GetterAndSetter{
  2.     private int x = 0;
  3.     public int getX() {
  4.         return x;
  5.     } 
  6.     public void setX(int x) {
  7.         this.x = x;
  8.     }
  9. }

Kotlin 是有屬性的:

 
 
 
 
  1. class KotlinGetterAndSetter{
  2.     var x: Int = 0
  3.         set(value) { field = value }
  4.         get() = field
  5. }

注意看到,我們?yōu)?x 顯式定義了 getter 和 setter,field 是 x 背后真正的變量,所以 setter 當(dāng)中其實(shí)就是為 field 賦值,而 getter 則是返回 field。如果你想要對(duì) x 的訪問(wèn)做控制,那么你就可以通過(guò)自定義 getter 和 setter 來(lái)實(shí)現(xiàn)了:

 
 
 
 
  1. class KotlinGetterAndSetter{
  2.     var x: Int = 0
  3.         set(value) {
  4.             val date = Calendar.getInstance().apply {
  5.                 set(2017, 2, 18)
  6.             }
  7.             if(System.currentTimeMillis() < date.timeInMillis){
  8.                 println("Cannot be set before 2017.3.18")
  9.             }else{
  10.                 field = value
  11.             }
  12.         }
  13.         get(){
  14.             println("Get field x: $field")
  15.             return field
  16.         }   
  17. }

10. 如何延遲初始化成員變量

Java 定義的類成員變量如果不初始化,那么基本類型被初始化為其默認(rèn)值,比如 int 初始化為 0,boolean 初始化為 false,非基本類型的成員則會(huì)被初始化為 null。

 
 
 
 
  1. public class Hello{
  2.     private String name;
  3. }

類似的代碼在 Kotlin 當(dāng)中直譯為:

 
 
 
 
  1. class Hello{
  2.     private var name: String? = null
  3. }

使用了可空類型,副作用就是后面每次你想要用 name 的時(shí)候,都需要判斷其是否為 null。如果不使用可控類型,需要加 lateinit 關(guān)鍵字:

 
 
 
 
  1. class Hello{
  2.     private lateinit var name: String
  3. }

lateinit 是用來(lái)告訴編譯器,name 這個(gè)變量后續(xù)會(huì)妥善處置的。

對(duì)于 final 的成員變量,Java 要求它們必須在構(gòu)造方法或者構(gòu)造塊當(dāng)中對(duì)他們進(jìn)行初始化:

 
 
 
 
  1. public class Hello{
  2.     private final String name = "Peter";
  3. }

也就是說(shuō),如果我要想定義一個(gè)可以延遲到一定實(shí)際再使用并初始化的 final 變量,這在 Java 中是做不到的。

Kotlin 有辦法,使用 lazy 這個(gè) delegate 即可:

 
 
 
 
  1. class Hello{
  2.     private val name by lazy{
  3.         NameProvider.getName() 
  4.     }
  5. }

只有使用到 name 這個(gè)屬性的時(shí)候,lazy 后面的 Lambda 才會(huì)執(zhí)行,name 的值才會(huì)真正計(jì)算出來(lái)。

11. 如何獲得 class 的實(shí)例

Java 當(dāng)中:

 
 
 
 
  1. public class Hello{
  2.     ...
  3. ... 
  4. Class clazz = Hello.class; 
  5. Hello hello = new Hello();
  6. Class clazz2 = hello.getClass();

前面我們展示了兩種獲得 class 的途徑,一種直接用類名,一種通過(guò)類實(shí)例。剛剛接觸 Kotlin 的時(shí)候,獲取 Java Class 的方法卻是容易讓人困惑。

 
 
 
 
  1. class Hello 
  2. val clazz = Hello::class.java 
  3. val hello = Hello()
  4. val clazz2 = hello.javaClass

同樣效果的 Kotlin 代碼看上去確實(shí)很奇怪,實(shí)際上 Hello::class 拿到的是 Kotlin 的 KClass,這個(gè)是 Kotlin 的類型,如果想要拿到 Java 的 Class 實(shí)例,那么就需要前面的辦法了。


網(wǎng)站名稱:快速入門Kotlin的11招
鏈接URL:http://m.5511xx.com/article/cocdsip.html