java序列化

来源:互联网 发布:射频版图设计软件 编辑:程序博客网 时间:2024/04/27 06:52

经常听到别人提到序列化问题,做了这么多年的程序猿也没有好好的了解一下,今天记录一下算是先了解一下序列化是怎么一回事。
java序列化可以通过ObjectOutputStream 和ObjectInputStream实现;
序列化:out.writeObject(obj)
反序列化:in.readObject()
注意
1、 序列化需要实现Serializable接口

2、 serialVersionUID 属性(为了兼容最好都加上一个默认值)

2.1 没有指定serialVersionUID默认值:
序列化时候会自动生成一个。如果对类进行修改比如添加删除属性,则反序列化时报错
local class incompatible: stream classdesc serialVersionUID = 3290345668099963788, local class serialVersionUID = 898001818966790349

2.2 如果累指定了serialVersionUID属性,对类属性进行修改,反序列话不会报错

3、 如果对象有继承父类,父类没有实现Serializable则,父类属性不会被序列化,只有父类也实现了Serializable,父类属性才会被序列化
4、 类的静态变量,以及使用@Transient修饰的字段,不会被序列化

public class News implements Serializable{    private static final long serialVersionUID = 8L;    private int id;    private String name;     public static String staticField="测试";     //省略了get、set方法    public String toString(){        return "id:"+this.id+",name:"+this.name+",staticField:"+News.staticField;    }}
    //测试类    public class SerizalObjTest {    //序列化    public void serzalObj(Object obj) throws Exception {        FileOutputStream fop = new FileOutputStream("D:/00/user.txt");        ObjectOutputStream out = new ObjectOutputStream(fop);        out.writeObject(obj);        out.close();        fop.close();    }    //反序列话    public Object parseObj() throws Exception {        FileInputStream fis = new FileInputStream("D:/00/user.txt");        ObjectInputStream in = new ObjectInputStream(fis);        Object obj = in.readObject();        in.close();        fis.close();        return obj;    }    public static void main(String[] args) throws Exception{        News n = new News();        n.setId(10);        n.setName("名称-hah");//      n.staticField="静态变量-不会序列化";        SerizalObjTest t = new SerizalObjTest();//      t.serzalObj(n);        News rstObj = (News)t.parseObj();        System.out.println(rstObj);    }}

参考:
http://blog.csdn.net/endlu/article/details/51178143
http://blog.csdn.net/jiangwei0910410003/article/details/18989711/
http://blog.csdn.net/wangloveall/article/details/7992448

原创粉丝点击