我正在尝试使用serialization.Message将消息写入文件,该文件由两个字段组成- date和TibrvMsg(TibrvMsg是Tibco的专有消息,根据他们的文档,这个类是不可序列化的).So我的自定义消息是:
Message msg = new Message(TibrvMsg msg)问题是,尽管我声明了Message Serializable,但我无法序列化它,因为TibrvMsg是不可序列化的。所以我得到了java.io.NotSerializableException: com.tibco.tibrv.TibrvMsg异常。
发布于 2010-08-23 18:03:29
另一种方法是使用serialization proxy。序列化代理是与使用对象的逻辑状态进行序列化的对象完全不同的类。对象readResolve()方法,用于编写代理而不是此对象,并通过读取代理来创建对象。
一些半伪码:
class Message implements Serializable {
private Date dt;
private TibrvMsg msg;
private Object writeReplace() {
return new Proxy(this);
}
private static class Proxy implements Serializable {
private Date dt;
private Map msgData;
Proxy(Message msg) {
this.dt = msg.dt;
this.msgData = doTransform(msg.msg, "UTF-16");
}
private Object readResolve() {
Message msg = new Message();
msg.dtd = dt;
msg.msg = asTibrvMsg(msgData);
return msg;
}
}
}另外,重写readObject(ObjectInputStream)以抛出InvalidObjectException。与普通序列化相比,序列化代理模式还具有一定的安全advantages。它也有一些disadvantages
发布于 2010-08-23 14:52:36
您需要找到一种方法将映射表示为可序列化的对象(可能是like this,它会将其转换为TibrvMsg )。
然后,您可以覆盖以下两个方法,以将此数据写入(或读取)输出流:
private void writeObject(java.io.ObjectOutputStream out)
throws IOException{
out.writeObject(date);
out.writeObject(doSomethingWithTibrv(tibrv);
}
private void readObject(java.io.ObjectInputStream in)
throws IOException, ClassNotFoundException{
date = (Date) in.readObject();
tibrv = readTibrv(in.readObject());
}发布于 2010-08-23 15:21:09
你说的“这个类根据他们的文档是不可序列化的”是什么意思?你可以仅仅扩展他们的类并实现serializable吗?这只是一个标记界面,所以...
https://stackoverflow.com/questions/3545243
复制相似问题