一、数据类
数据类通常需要重写equals(),hashCode(),toString()这几个方法。
equals():用于判断两个数据类是否相等
hashCode():作为equals()的配套方法,也需要一起重写,否则会导致HashMap、HashSet等Hash相关的系统类无法正常工作
toString():用于提供更清晰的输入日志
如果我们使用Java来实现一个数据类:
public class Phone {
double price;
String brand;
public Phone(double price, String brand) {
this.price = price;
this.brand = brand;
}
@Override
public boolean equals(@Nullable Object obj) {
if (obj instanceof Phone) {
Phone phone = (Phone) obj;
return phone.brand.equals(brand) & phone.price == price;
}
return false;
}
@Override
public int hashCode() {
return brand.hashCode() + (int) price;
}
@Override
public String toString() {
return "Phone{" +
"price=" + price +
", brand='" + brand + '\'' +
'}';
}
}
看上去很复杂,而且这些代码都是没有实际意义的代码,只是为了让他拥有数据类型的功能而已。我们看Kotlin怎么实现数据类:
data class Phone(val brand: String, val price: Double)
是的你没看错,就只需要一行代码。
在一个类前面声明了data关键字,就表示你希望这个类是一个数据类,Kotlin会根据主构造函数中的参数帮你将equals(),hashCode(),toString()等固定且无实际意义的代码自动生成,大大减少了开发量。
另外,当一个类中没有任何代码时,还可以将尾部的大括号省去。
二、单例类
在Java中我们写一个单例类,有懒汉式、饿汉式、双重加锁这几种,都是需要私有化构造方法,给外部提供一个getInstance()静态方法用于获得单例类的实例。虽然也不复杂,但是Kotlin明显做的更好:
object Singleton {
fun singletonTest() {
println("singletonTest is called ")
}
}
没错,我们只需把class改为object关键字,一个单例类就创建完成了。调用也很简单:
fun main() {
Singleton.singletonTest()
//输出日志:singletonTest is called
}
这种写法看上去像是静态方法的调用,但其实Kotlin在背后自动帮我们创建了一个Singleton的实例,并且保证全局只会存在一个Singleton实例。