困惑,java序列化replaceWrite和readObject的问题
太长了,度娘不让放,而且代码没着色不容易看,请移步,谢谢!http://www.oschina.net/question/1185740_126606...
太长了,度娘不让放,而且代码没着色不容易看,请移步,谢谢!
http://www.oschina.net/question/1185740_126606 展开
http://www.oschina.net/question/1185740_126606 展开
4个回答
展开全部
Student s=new Student();
s.setName("123");
s.setScore(100);
你给name和score都赋值了,这个对象序列化的时候,name=123,score=100;反序列化当然是一样的,输出123=100。
追问
在readObject里我put进一个key=“123”,value=0,将原来的覆盖了,所以读取的应该是123=0
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.Serializable;
public class TestSerializable implements Serializable {
private String name;
private int score;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getScore() {
return score;
}
public void setScore(int score) {
this.score = score;
}
public static void main(String[] args) throws IOException, ClassNotFoundException {
TestSerializable obj = new TestSerializable();
obj.setName("test");
obj.setScore(100);
ByteArrayOutputStream baos = new ByteArrayOutputStream();
ObjectOutputStream oos = new ObjectOutputStream(baos);
oos.writeObject(obj);
baos.flush();
baos.close();
byte[] data = baos.toByteArray();
ByteArrayInputStream bais = new ByteArrayInputStream(data);
ObjectInputStream ois = new ObjectInputStream(bais);
TestSerializable test = (TestSerializable) ois.readObject();
System.out.println(test.getName()+":"+test.getScore());
}
}
更多追问追答
追问
什么意思?一切尽在不言中????我重写readObject方法了啊
追答
应该是如果你定义了writeReplace和readResolve,那么就不会调用readObject和writeObject
writeObject应该是你自己向OutputStream中写变量值,readObject是你自己从InputStream中根据writeObject写的顺序读取变量值。但是如果你定义了writeReplace,系统就会直接调用writeReplace来从新向流中写对象,如果定义了readResolve同理。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
ASFDAFDAFADFD 阿萨德
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询