通过实例了解java序列化机制
这篇文章主要介绍了通过实例了解java序列化机制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
序列化是指对象通过写出描述自己状态的数值来记录自己的过程,即将对象表示成一系列有序字节,Java提供了将对象写入流和从流中恢复对象的方法。对象能包含其它的对象,而其它的对象又可以包含另外的对象。Java序列化能够自动的处理嵌套的对象。对于一个对象的简单域,writeObject()直接将其值写入流中。
当遇到一个对象域时,writeObject()被再次调用,如果这个对象内嵌另一个对象,那么,writeObject()又被调用,直到对象能被直接写入流为止。程序员所需要做的是将对象传入ObjectOutputStream的writeObject()方法,剩下的将有系统自动完成。
要实现序列化的类必须实现的java.io.Serializable或java.io.Externalizable接口,否则将产生一个NotSerializableException。该接口内部并没有任何方法,它只是一个"tagginginterface",仅仅"tags"它自己的对象是一个特殊的类型。
类通过实现java.io.Serializable接口以启用其序列化功能。未实现此接口的类将无法使其任何状态序列化或反序列化。可序列化类的所有子类型本身都是可序列化的。
序列化接口没有方法或字段,仅用于标识可序列化的语义。Java的"对象序列化"能让你将一个实现了Serializable接口的对象转换成一组byte,这样日后要用这个对象时候,你就能把这些byte数据恢复出来,并据此重新构建那个对象了。
代码如下
packagestream; importjava.io.FileInputStream; importjava.io.FileNotFoundException; importjava.io.FileOutputStream; importjava.io.IOException; importjava.io.ObjectInputStream; importjava.io.ObjectOutputStream; importjava.io.Serializable; importjavax.security.auth.login.AccountException; importorg.junit.jupiter.api.Test; /* *对象流 *用与存储和读取基本数据类型数据或对象的处理刘。它的强大之处就是可以把java中的对象转换成流 * **/ publicclassObjectInputStreamTeat{ /* *序列化过程:将内存中的java对象保存到磁盘或通过网络传输出去 *使用ObjectOutputStream **/ @Test publicvoidtestObjectOutputStream(){ ObjectOutputStreamoos=null; try{ oos=newObjectOutputStream(newFileOutputStream("Object.dat")); oos.writeObject(newString("我是中国人")); oos.flush(); oos.writeObject(newPerson("zsben",1,newAccount(2000))); oos.flush(); }catch(Exceptione){ e.printStackTrace(); } finally{ try{ if(oos!=null) oos.close(); }catch(Exceptione){ e.printStackTrace(); } } } /* *反序列化:用ObjectInputStream实现 **/ @Test publicvoidtestObjectInputStream(){ ObjectInputStreamois=null; try{ ois=newObjectInputStream(newFileInputStream("Object.dat")); Objectobject=ois.readObject(); Stringstring=(String)object; System.out.println(string); Objectobject2=ois.readObject(); Personperson=(Person)object2; System.out.println(person); }catch(Exceptione){ e.printStackTrace(); } finally{ try{ if(ois!=null) ois.close(); }catch(Exceptione){ e.printStackTrace(); } } } } /* *1.Person类要实现可序列化,必须实现可序列化接口Serializable *2.还需要添加一个最终类属性UID *3.除了当前Person类需要实现Serializable,还要保证其内部所有属性都是可序列化的 *(默认情况下基本数据类型为可序列化) *对象流不能序列化static和transient修饰的成员 **/ classPersonimplementsSerializable{ publicstaticfinallongserivalVersionUID=5432146546351568416L; privateStringname; privatestaticintage; privateAccountaccount; @Override publicStringtoString(){ return"Person[name="+name+",age="+age+",account="+account+"]"; } publicStringgetName(){ returnname; } publicvoidsetName(Stringname){ this.name=name; } publicintgetAge(){ returnage; } publicvoidsetAge(intage){ this.age=age; } publicPerson(Stringname,intage){ super(); this.name=name; this.age=age; } publicPerson(Stringname,intage,Accountaccount){ super(); this.name=name; this.age=age; this.account=account; } publicPerson(){ super(); } } classAccountimplementsSerializable{ privatedoublebalance; staticfinalpubliclongserivalVersionUID=54685237864535874L; @Override publicStringtoString(){ return"Account[balance="+balance+"]"; } publicdoublegetBalance(){ returnbalance; } publicvoidsetBalance(doublebalance){ this.balance=balance; } publicAccount(doublebalance){ super(); this.balance=balance; } publicAccount(){ super(); } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。