开发者社区> 问答> 正文

JAVA中序列化及反序列化如何理解?

JAVA中序列化及反序列化如何理解?

展开
收起
vncamyi27xznk 2021-11-17 08:11:23 2142 0
2 条回答
写回答
取消 提交回答
  • 1、 在 Java 中,只要一个类实现了 java.io.Serializable 接口,那么它就可以被序列化。 2、 通过 ObjectOutputStream 和 ObjectInputStream 对对象进行序列化及反序列化。 private static final long serialVersionU 3、 虚拟机是否允许反序列化,不仅取决于类路径和功能代码是否一致,一个非常重要的一点是两个类的序列化 ID 是否一致(就是 ID)。 4、 序列化并不保存静态变量。 5、 要想将父类对象也序列化,就需要让父类也实现 Serializable 接口。 6、 Transient 关键字的作用是控制变量的序列化,在变量声明前加上该关键字,可以阻止该变量被序列化到文件中,在被反序列化后,transient 变量的值被设为初始值,如 int 型的是 0,对象型的是 null。 7、 服务器端给客户端发送序列化对象数据,对象中有一些数据是敏感的,比如密码字符串等,希望对该密码字段在序列化时,进行加密,而客户端如果拥有解密的密钥,只有在客户端进行反序列化时,才可以对密码进行读取,这样可以一定程度保证序列化对象的数据安全。 资料来源:《Java工程师成神之路(基础篇)》,链接:https://developer.aliyun.com/topic/download?id=923

    2021-11-17 15:51:09
    赞同 展开评论 打赏
  • 热爱成就非凡

    序列化是将对象的状态信息转换为可以存储或传输的形式的过程。在序列化期间,对象将其当前状态写入到临时或持久性存储区。以后,可以通过从存储区中读取或反序列化对象的状态,重新创建该对象。

    序列化和反序列化是对某个对象的计算暂停和重启,将对象数据从计算态转变成存储态、传输态。

    2021-11-17 08:58:25
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
Spring Cloud Alibaba - 重新定义 Java Cloud-Native 立即下载
The Reactive Cloud Native Arch 立即下载
JAVA开发手册1.5.0 立即下载