上月咱们聊到了Gson序列化对象时在kotlin中应用的并不太完美,点击相关讨论查阅.这次咱们就浅析下kotlin序列化框架,简单的应用.上篇文章结尾有提到应用前准备的相关内容,这里不在重复叙述.
如果您足够仔细会发现前一篇文章的准备类A所定义的属性都是基本类型,首先我们讨论下不是基本类型,kotlin序列化框架的处理.我们在类A新加Date类型的属性:
data class A(var b: Int , var c: String = "kotlin",var e : Date) {
private var a: String = "kotlinx"
override fun toString(): String {
return "A(b=$b, c='$c', a=$a,e=$e)"
}
}
序列化对象A:
println(JSON.stringify(A(1,"kotlinx",DateUtils.parseDate("2018-10-01","yyyy-MM-dd"))))
其中DateUtils是我自定义工具类(String To Date)
测试结果:
会发现Date类型e被序列化成不是咱们想要的时间格式 (yyyy-MM-dd),那如何实现Date
自定义序列化的格式呢?首先,我们要定义个DateSerializers来实现自定义序列化
@Serializer(Date::class)
object DateSerializers : KSerializer<Date>{
override fun load(input: KInput)=DateUtils.parseDate(input.readStringValue(),"yyyy-MM-dd")
override fun save(output: KOutput , obj: Date) {
output.writeStringValue(DateUtils.formatDate(obj,"yyyy-MM-dd"))
}
override val serialClassDesc: KSerialClassDesc
get() = TODO("not implemented") //To change initializer of created properties use File | Settings | File Templates.
}
重写load和save方法,使用时注明Serializable
@kotlinx.serialization.Serializable(DateSerializers::class) val e : Date
测试结果:
就是我们想要的日期格式了,当然Date也可以换成我们自定义的其他类(MyClass),自定义的规则在MySerializer中进行重写,并注册MyClass后才能使用.save
方法可以让我们在序列化 Date(or MyClass)
的对象时按我们自定义需求的形式进行输出,load
方法则用于反序列化.