Mar*_*kus 23 parcelable kotlin parceler
有没有办法使用Parceler与Kotlin数据类和构造函数进行序列化而不使用@ParcelProperty每个字段的注释?
如果我尝试使用这样的库:
@Parcel
data class Valve @ParcelConstructor constructor(val size: Int)
Run Code Online (Sandbox Code Playgroud)
我得到Error:Parceler: No corresponding property found for constructor parameter arg0.但如果我添加@ParcelProperty("size")它就可以了.
这是为什么?
更新:
还有其他方法可以使用此库.
我可以删除@ParcelConstructor注释,但后来我会得到错误
Error:Parceler: No @ParcelConstructor annotated constructor and no default empty bean constructor found.
我认为(没有测试过)我也可以使所有构造函数参数可选并添加@JvmOverloads但是有副作用,我必须检查类的所有属性,如果它们是是否为空.
更新2:
这对我有用:
@Parcel
data class Valve(val size: Int? = null)
Run Code Online (Sandbox Code Playgroud)
简而言之,生成的Java类必须具有默认的空构造函数.实现这一目标的一种方法是如上所述 - 所有变量都应该具有默认值.
vod*_*dan 26
根据文档,Parceler默认使用公共字段.但是通常的Kotlin data class(在你的例子中)是一个"传统的getter/setter bean",因为每个Kotlin属性都由私有字段和getter/[setter]表示.
TL; DR:我认为这会奏效:
@Parcel(Serialization.BEAN)
data class Valve(val size: Int = 10)
Run Code Online (Sandbox Code Playgroud)
注意默认值,它允许Kotlin自动生成一个额外的空构造函数,这是Java Been规范所要求的.
另一种方法是标记我们已经拥有的构造函数:
@Parcel(Serialization.BEAN)
data class Driver @ParcelConstructor constructor(val name: String)
Run Code Online (Sandbox Code Playgroud)
具体文件:https://github.com/johncarl81/parceler#gettersetter-serialization
Bra*_*ell 10
我知道这个问题已经有了答案,但是对于那些也在努力让Parceler使用kotlin数据对象的未来观众,我写了一个新的注释处理器来为Kotlin数据类生成Parcelable样板.它旨在大规模减少样板代码,使您的数据类Parcelable:
https://github.com/grandstaish/paperparcel
用法:
使用@PaperParcel,实现PaperParcelable和添加生成的JVM静态实例来注释您的数据类,CREATOR例如:
@PaperParcel
data class Example(
val test: Int,
...
) : PaperParcelable {
companion object {
@JvmField val CREATOR = PaperParcelExample.CREATOR
}
}
Run Code Online (Sandbox Code Playgroud)
现在您的数据类是Parcelable并且可以直接传递给Bundle或Intent
编辑:使用最新API进行更新
只需添加默认构造函数:
@Parcel
data class Valve(val size: Int) {
constructor() : this(0)
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
8729 次 |
| 最近记录: |