kotlin使用jackson序列化enum

默认情况下,我们序列化与反序列化enum是它的name,事实上大部分情况下我们需要序列化的是我们自定义的value,那应该怎么做呢?

这种情况下我们就需要@JsonValue与@JsonCreator

data class User(var id:Int = 0,
                var name:String="",
                var birthday:LocalDateTime? = null,
                //@get:JsonProperty("orderID")
                var orderId:String? = null,
                var userType:UserType = UserType.ADMIN
)
enum class UserType(
        //指定typeValue序列化
        @get:JsonValue
        val typeValue: Int
) {
    ADMIN(2),
    USER(4);


    companion object {
	    //指定creator反序列化
        @JsonCreator
        @JvmStatic
        fun creator(typeValue: Int):UserType{
            val found = UserType.values().find { it.typeValue == typeValue }
            return found ?: throw IllegalArgumentException("not found IconEnum with $typeValue")

        }
    }

}

那我们用jackson进行序列化及序列化操作,试一下

  val u = User(1, "st", birthday = LocalDateTime.now(),orderId = "123",userType = UserType.ADMIN)
val json = u.toJson()
    println(json)
    println(json.fromJson<User>())

输出

{"id":1,"name":"st","birthday":"2019-01-17T20:08:58.515","orderId":"123","userType":2}
User(id=1, name=st, birthday=2019-01-17T20:08:58.515, orderId=123, userType=ADMIN)

转载于:https://my.oschina.net/weidedong/blog/3002932

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Kotlin使用序列化读写文件可以通过以下步骤实现: 1. 首先,你需要创建一个数据类,该数据类将被序列化到文件中。例如,假设我们有一个名为 `Person` 的数据类,包含姓名和年龄属性: ```kotlin import java.io.Serializable data class Person(val name: String, val age: Int) : Serializable ``` 2. 接下来,你需要将对象序列化并写入文件。可以使用 `ObjectOutputStream` 来完成这个任务。下面是一个示例代码: ```kotlin import java.io.FileOutputStream import java.io.ObjectOutputStream fun writeObjectToFile(obj: Any, filePath: String) { val fileOutputStream = FileOutputStream(filePath) val objectOutputStream = ObjectOutputStream(fileOutputStream) objectOutputStream.writeObject(obj) objectOutputStream.close() fileOutputStream.close() } ``` 在上述代码中,`writeObjectToFile` 函数接受一个对象和文件路径作为参数,并将对象序列化后写入文件。 3. 最后,你可以使用 `ObjectInputStream` 从文件中读取已序列化的对象。以下是读取文件并反序列化对象的示例代码: ```kotlin import java.io.FileInputStream import java.io.ObjectInputStream fun readObjectFromFile(filePath: String): Any { val fileInputStream = FileInputStream(filePath) val objectInputStream = ObjectInputStream(fileInputStream) val obj = objectInputStream.readObject() objectInputStream.close() fileInputStream.close() return obj } ``` 在上述代码中,`readObjectFromFile` 函数接受文件路径作为参数,并返回从文件中读取并反序列化的对象。 使用上述代码,你可以将 `Person` 对象序列化并写入文件,然后从文件中读取并反序列化对象。以下是一个示例: ```kotlin fun main() { val person = Person("Alice", 25) val filePath = "person.ser" // 将对象序列化并写入文件 writeObjectToFile(person, filePath) // 从文件中读取并反序列化对象 val deserializedPerson = readObjectFromFile(filePath) as Person println(deserializedPerson) } ``` 上述示例中,我们先将 `Person` 对象序列化并写入文件,然后从文件中读取并反序列化对象,并最终打印出反序列化后的对象。 请注意,上述代码只是一个简单示例,你可以根据实际需求进行修改和扩展。此外,还需要注意的是,序列化的类需要实现 `java.io.Serializable` 接口。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值