数据类
我们经常创建一些只保存数据的类。在这些类中,一些标准函数往往是从数据机械推导而来的。在 Kotlin 中,这叫做 数据类 并标记为 data:
data class User(val name: String, val age: Int)
编译器自动从主构造函数中声明的所有属性导出以下成员:
- equals()/hashCode() 对,
- toString() 格式是 “User(name=John, age=42)”,
- componentN() 函数 按声明顺序对应于所有属性,
- copy() 函数(见下文)。
如果这些函数中的任何一个在类体中显式定义或继承自其基类型,则不会生成该函数。
为了确保生成的代码的一致性和有意义的行为,数据类必须满足以下要求:
- 主构造函数需要至少有一个参数;
- 主构造函数的所有参数需要标记为 val 或 var;
- 数据类不能是抽象、开放、密封或者内部的;(在1.1之前)数据类只能实现接口。
在 JVM 中,如果生成的类需要含有一个无参的构造函数,则所有的属性必须指定默认值。
data class User(val name: String = "", val age: Int = 0)
复制
在很多情况下,我们需要复制一个对象改变它的一些属性,但其余部分保持不变。 copy() 函数就是为此而生成。对于上文的 User 类,其实现会类似下面这样:
fun copy(name: String = this.name, age: Int = this.age) = User(name, age)
这让我们可以写
val jack = User(name = "Jack", age = 1)
val olderJack = jack.copy(age = 2)
用gson解析json数据
json数据如下:
{
"daily_forecast": [
{
"date": "2017-7-25",
"cond": {
"txt_d": "阵雨"
},
"tmp": {
"max": "34",
"min": "27"
}
},
{
"date": "2017-7-26",
"cond": {
"txt_d": "晴"
},
"tmp": {
"max": "38",
"min": "27"
}
}
]
}
首先新建一个Kotlin文件,然后写数据类:
注意:当我们使用Gson来解析json到我们的类中,这些属性的名字必须要与json中的名字一样,或者可以指定一个serialised name(序列化名称)。
data class Weather(@SerializedName("daily_forecast") val forecast:List<Forecast>){}
data class Forecast(val date:String,@SerializedName("cond") val more:More,@SerializedName("tmp") val temperature:Temperature){}
data class Temperature (val max:String,val min:String) {}
data class More (@SerializedName("txt_d") val info:String){}
最后测试用Gson解析json数据:
fun main(args: Array<String>) {
val json:String="""{
"daily_forecast": [
{
"date": "2017-7-25",
"cond": {
"txt_d": "阵雨"
},
"tmp": {
"max": "34",
"min": "27"
}
},
{
"date": "2017-7-26",
"cond": {
"txt_d": "晴"
},
"tmp": {
"max": "38",
"min": "27"
}
}
]
}"""
var weather:Weather=Gson().fromJson(json,Weather::class.java)
println(weather.toString())
}
输出结果:
Weather(forecast=[Forecast(date=2017-7-25, more=More(info=阵雨), temperature=Temperature(max=34, min=27)), Forecast(date=2017-7-26, more=More(info=晴), temperature=Temperature(max=38, min=27))])
Process finished with exit code 0