成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

快速上手Kotlin的11招

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

[[195896]]

最近經常會收到一些 “用 Kotlin 怎么寫” 的問題,作為有經驗的程序員,我們已經掌握了一門或者多門語言,那么學 Kotlin 的時候就經常會有類似 “ ‘再見’用日語怎么說?”、“ ‘你好’ 用西班牙語怎么說?” 的問題,所以我決定把一些常用的語法對照列舉出來,如果大家熟悉 Java,那么快速上手 Kotlin 會變得非常地容易。

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

1. 如何定義變量

Java 定義變量的寫法:

  1. String string = "Hello"

基本等價的 Kotlin 定義變量的寫法:

  1. var string: String = "Hello" 

Java 定義 final 變量的寫法:

  1. final String string = "Hello"

注意到前面的是一個編譯期常量,Kotlin 當中應該這么寫:

  1. const val string: String = "Hello" 

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

  1. final String string = getString(); 

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

  1. val string: String = getString() 

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

2. 如何定義函數

Java 當中如何定義函數,也就是方法,需要定義到一個類當中:

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

等價的 Kotlin 寫法: 

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

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

3. 如何定義靜態變量、方法

Java 的靜態方法或者變量只需要加一個 static 即可:

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

用 Kotlin 直譯過來就是:   kotlin class KotlinSingleton{ companion object{ private val kotlinSingleton = KotlinSingleton()   @JvmStatic fun getInstance() = kotlinSingleton   } } 注意 getInstance 的寫法。 JvmStatic 這個注解會將 getInstance 這個方法編譯成與 Java 的靜態方法一樣的簽名,如果不加這個注解,Java 當中無法像調用 Java 靜態方法那樣調用這個方法。

另外,對于靜態方法、變量的場景,在 Kotlin 當中建議使用包級函數。

4. 如何定義數組

Java 的數組非常簡單,當然也有些抽象,畢竟是編譯期生成的類:

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

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

  1. val names: Array<String> = arrayOf("Kyo""Ryu""Iory")  
  2. val emptyStrings: Array<String?> = arrayOfNulls(10)   

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

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

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

5. 如何寫變長參數

Java 的變長參數寫法如下:

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

Kotlin 的變長參數寫法如下:

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

6. 如何寫三元運算符

Java 可以寫三元運算符:

  1. int code = isSuccessfully? 200: 400; 

很多人抱怨 Kotlin 為什么沒有這個運算符。。。據說是因為 Kotlin 當中 : 使用的場景比 Java 復雜得多,因此如果加上這個三元運算符的話,會給語法解析器帶來較多的麻煩,Scala 也是類似的情況。那么這中情況下,我們用 Kotlin 該怎么寫呢?

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

注意到,if else 這樣的語句也是表達式,這一點與 Java 不同。

7. 如何寫 main 函數

Java 的寫法只有一種:

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

注意到參數可以是變長參數或者數組,這二者都可。

對應 Kotlin,main 函數的寫法如下:

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

Kotlin 可以有包級函數,因此我們并不需要聲明一個類來包裝 main 函數:

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

8. 如何實例化類

Java 和 C++ 這樣的語言,在構造對象的時候經常需要用到 new 這個關鍵字,比如:

  1. Date date = new Date(); 

Kotlin 構造對象時,不需要 new 這個關鍵字,所以上述寫法等價于:

  1. val date = Date() 

9. 如何寫 Getter 和 Setter 方法

Java 的 Getter 和 Setter 是一種約定俗稱,而不是語法特性,所以定義起來相對自由:

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

Kotlin 是有屬性的: 

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

注意看到,我們為 x 顯式定義了 getter 和 setter,field 是 x 背后真正的變量,所以 setter 當中其實就是為 field 賦值,而 getter 則是返回 field。如果你想要對 x 的訪問做控制,那么你就可以通過自定義 getter 和 setter 來實現了:

  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.         }     }   

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

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

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

類似的代碼在 Kotlin 當中直譯為:

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

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

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

lateinit 是用來告訴編譯器,name 這個變量后續會妥善處置的。

對于 final 的成員變量,Java 要求它們必須在構造方法或者構造塊當中對他們進行初始化:

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

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

Kotlin 有辦法,使用 lazy 這個 delegate 即可:

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

只有使用到 name 這個屬性的時候,lazy 后面的 Lambda 才會執行,name 的值才會真正計算出來。

11. 如何獲得 class 的實例

Java 當中:

  1. public class Hello{  
  2.     ...  
  3.  }  
  4.     
  5.  ...  
  6.     
  7.  Class<?> clazz = Hello.class;  
  8.     
  9.  Hello hello = new Hello();  
  10.  Class<?> clazz2 = hello.getClass();   

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

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

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

責任編輯:龐桂玉 來源: Kotlin
相關推薦

2017-06-14 17:50:44

Kotlin寫法Java

2021-10-21 22:56:56

Windows 11Windows微軟

2011-07-26 13:58:17

LINQ

2022-06-04 07:26:47

Thanos集群Prometheus

2013-11-19 12:53:33

OA信息化

2021-12-10 08:13:02

MatplotlibpythonAPI

2022-08-19 07:13:45

SQL方法編程

2022-08-21 07:17:16

LinkerdKubernetes服務網格

2020-10-26 08:31:41

Python爬蟲開發

2010-05-18 10:17:11

2011-07-25 15:42:58

XML

2023-06-13 08:00:57

ChatGPT語言模型

2024-01-29 00:36:50

Backstage設施工具

2024-01-06 09:58:22

2011-05-04 13:24:39

Ubuntu 11.0

2018-04-24 10:05:13

Docker工具交付

2021-11-26 09:40:37

EclipseIDEA開發

2020-11-27 09:40:53

Rollup前端代碼

2009-11-05 09:51:14

WCF基礎

2024-03-26 00:00:01

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美日韩一卡 | 国产 日韩 欧美 在线 | 午夜久久久 | 国产精品一级 | 青娱乐av| 亚洲欧美日韩系列 | 亚洲日韩中文字幕一区 | 一区二区三区四区视频 | 国产高清视频 | 久久久久久免费毛片精品 | 亚洲一区二区三区四区av | 久久只有精品 | 亚洲精品国产区 | 黄视频在线网站 | 中文字幕在线电影观看 | 日韩在线一区二区三区 | 中文字幕日韩欧美 | 亚洲精品一区二区在线 | 国产你懂的在线观看 | 自拍在线 | 国产乱码精品一区二区三区中文 | 精品国产一区二区国模嫣然 | 国产欧美视频一区二区 | 国产成人精品一区二区三区 | 日韩在线国产精品 | 一区二区三区欧美 | 亚洲精品视频三区 | 久久精品黄色 | japanhd成人 | 九九九久久国产免费 | 日中文字幕在线 | 久久青视频| 亚洲成人在线免费 | 成人精品福利 | 波多野结衣一区二区三区在线观看 | 免费黄色av | 精品欧美激情在线观看 | 日韩成年人视频在线 | 中文字幕在线一区二区三区 | 免费人成在线观看网站 | 亚洲天堂中文字幕 |