Kotlin中equals方法與==,===

先看一段代碼:java

1 fun main(args: Array<String>) {
2     val person1 = Person(1,"liuliqianxiao")
3     val person2 = Person(1,"liuliqianxiao")
4     println(person1 == person2)//false
5 }
6 
7 class Person(var id: Int, var name: String) {
8     
9 }

自定義了一個類以後,自然的就能使用==運算符。這是由於Kotlin中==運算符會調用到equals函數,而equals是根類Any上定義的方法(這裏我沒找到Any上equals方法的實現)。ide

這裏很容跟其餘運算符重載的特性,致使一個慣性思惟就是a == b就是調用的 a.equals(b),其實否則,a == b實際上是以下調用過程:函數

默認實現的equals也許不是咱們想要的而結果,此時能夠自行重寫equals方法。試着給Person類實現它本身的equals,偷個懶,直接idea快捷鍵生成吧:this

 1 class Person(var id: Int, var name: String) {
 2     override fun equals(other: Any?): Boolean {
 3         if (this === other) return true
 4         if (other?.javaClass != javaClass) return false
 5 
 6         other as Person
 7 
 8         if (id != other.id) return false
 9         if (name != other.name) return false
10 
11         return true
12     }
13 
14     override fun hashCode(): Int {
15         var result = id
16         result = 31 * result + name.hashCode()
17         return result
18     }
19 }

此處ide自動生成的equals略顯囉嗦,能夠稍微簡化下,以下代碼:idea

1     override fun equals(other: Any?): Boolean {
2         if (this === other) return true
3         if (other !is Person) return false
4 
5         return this.id == other.id && this.name == other.name
6     }

這裏看到運算符重載,咱們並無加上operator關鍵字,這也是由於equals是在根類Any上定義的,已經加上了operator修飾符,以下:spa

public open operator fun equals(other: Any?): Boolean

因此子類只須要override就能夠。code

還有一點須要注意的是equals不能以擴展函數的形式實現。這是由於從Any繼承來的equals方法優先級高於擴展函數。blog

 在Kotlin中 ===運算符就至關於java中的==,比較的是兩個引用是否相等。繼承

!=運算符其實也是調用了equalshash

相關文章
相關標籤/搜索