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

相关文章
相关标签/搜索