序列化NotSerializableException问题

简介:  54powermanhttp://54powerman.blog.sohu.com 背景:某项目中,要将某个自定义类MMessage对象,通过ObjectOutputStream和ObjectInputStream传递,该MMessage的特征描...

 54powerman
http://54powerman.blog.sohu.com

背景:
某项目中,要将某个自定义类MMessage对象,通过ObjectOutputStream和ObjectInputStream传递,该MMessage的特征描述:
1 该类未继承Serializable接口;
2 其父类Message的父类继承了Serializable接口;
3 其父类中有一个字段类型为java.io.ByteArrayOutputStream类型;
经测试发现,MMessage类序列化过程中,会抛出NotFoundSerializableException,提示如下:
Exception in thread "main" java.io.NotSerializableException: java.io.ByteArrayOutputStream

错误排查:
1 从错误来看,首先想到了看一下MMessage是否继承了Serializable接口,发现其父类的父类继承了Serializable接口,理论上,作为子类的MMessage也应该是可以被序列化的;
2 测试序列化其父类以及父类的父类,发现其父类的父类,可以被序列化,但其父类无法序列化;
3 从上面的分析,问题出在其父类上。再仔细查看错误提示,并分析其父类Message的成员,断定是ByteArrayOutputStream成员无法被序列化(重新定义一个测试用例测试,验证了这一断言)。
4 修改Message类的成员ByteArrayOutputStream buff为transient类型,问题解决。

错误分析:
如果一个类的某个字段不需要被序列化,需要标注该字段为transient类型。适用的情况:
1 该字段为Object,而且该Object不能修改,且不可序列化;
2 该字段为可序列化类型,但它是敏感信息,如密码;
3 该字段为临时变量,如buffer,不需序列化;
例(代码片段):
public class SupperMessage implements Serializable
{
 //......
}
public class Message extends SupperMessage
{
 transient private java.io.ByteArrayOutputStream buff;//此对象无法序列化,且无法更改
 //......
}
public class MMessage extends Message
{
 private String contentId;
 private String user;
 transient private String pass;//敏感信息
 transient private String reserve;//不关心该字段,不需要序列化
 //......
}

类MMessage中标记为transient的成员,不会被序列化。

目录
相关文章
|
8月前
|
存储 C#
C#中的序列化和反序列化
C#中的序列化和反序列化
|
缓存 安全 网络协议
对象的序列化与反序列化详解
对象的序列化与反序列化详解
122 0
对象的序列化与反序列化详解
|
前端开发 Shell 数据库
序列化使用
序列化使用
|
存储 Java
序列化
序列化
82 0
|
存储 Java
序列化和反序列化
序列化和反序列化
81 0
序列化与反序列化
序列化与反序列化
69 0
|
JSON IDE Java
浅谈序列化与反序列化
浅谈序列化与反序列化
浅谈序列化与反序列化
|
存储 Java 数据库
什么是序列化
问题来了,什么是序列化呢?相信很多人都不太清楚,那我就把我的理解分享给大家
134 0
|
XML 存储 JSON
详解C# 序列化和反序列化
详解C# 序列化和反序列化
198 0
详解C# 序列化和反序列化
|
Java 开发者 容器
序列化与反序列化处理|学习笔记
快速学习 序列化与反序列化处理
147 0
序列化与反序列化处理|学习笔记