通过实例了解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(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。