如何实现java序列化
① 什么是java序列化,如何实现java序列化
序 列 化: 指把堆内存中的Java对象数据,通过某种方式把对象存储到磁盘文件中或者传递给其他网络的节点(在网络上传输).我们把这个过程称之为序列化.
反序列化:把磁盘文件中的对象数据或者把网络节点上的对象数据,恢复成Java对象的过程.
为什么要做序列化:
1):在分布式系统中,需要共享的数据的JavaBean对象,都得做序列化,此时需要把对象再网络上传输,此时就得把对象数据转换为二进制形式.以后存储在HttpSession中的对象,都应该实现序列化接口(只有实现序列化接口的类,才能做序列化操作).
2):服务钝化:如果服务发现某些对象好久都没有活动了,此时服务器就会把这些内存中的对象,持久化在本地磁盘文件中(Java对象-->二进制文件).如果某些对象需要活动的时候,现在内存中去寻找,找到就使用,找不到再去磁盘文件中,反序列化我们得对象数据,恢复成Java对象.
需要做序列化的对象的类,必须实现序列化接口:java.io.Serializable接口(标志接口[没有抽象方法]).
底层会判断,如果当前对象是Serializable的实例,才允许做序列化. boolean ret = Java对象 instanceof Serializable;
在Java中大多数类都已经实现Serializable接口.
② java中如何实现序列化,有什么意义
首先我们要把准备要序列化类,实现 Serializabel接口
例如:我们要Person类里的name和age都序列化
import java.io.Serializable;
public class Person implements Serializable { //本类可以序列化
private String name ;
private int age ;
public Person(String name,int age){
this.name = name ;
this.age = age ;
}
public String toString(){
return "姓名:" + this.name + ",年龄" + this.age ;
}
}
然后:我们将name和age序列化(也就是把这2个对象转为二进制,统族理解为“打碎”)
package org.lxh.SerDemo;
import java.io.File;
import java.io.FileOutputStream;
import java.io.ObjectOutputStream ;
public class ObjectOutputStreamDemo { //序列化
public static void main(String[] args) throws Exception {
//序列化后生成指定文件路径
File file = new File("D:" + File.separator + "person.ser") ; ObjectOutputStream oos = null ;
//装饰流(流)
oos = new ObjectOutputStream(new FileOutputStream(file)) ;
//实例化类
Person per = new Person("张三",30) ; oos.writeObject(per) ;//把类对象序列化
oos.close() ;
}
}
③ 什么是序列化,在java中如何实现序列化
一、什么是序列化:
序列化理解成“打碎”是可以的,不过在书本上的名词就是将对象转换成二进制。
二、在java中如何实现序列化:
首先我们要把准备要序列化类,实现 Serializabel接口
例如:我们要Person类里的name和age都序列化
import java.io.Serializable;
public class Person implements Serializable { //本类可以序列化
private String name ;
private int age ;
public Person(String name,int age){
this.name = name ;
this.age = age ;
}
public String toString(){
return "姓名:" + this.name + ",年龄" + this.age ;
}
}
然后:我们将name和age序列化(也就是把这2个对象转为二进制,统族理解为“打碎”)
package org.lxh.SerDemo;
import java.io.File;
import java.io.FileOutputStream;
import java.io.ObjectOutputStream ;
public class ObjectOutputStreamDemo { //序列化
public static void main(String[] args) throws Exception {
//序列化后生成指定文件路径
File file = new File("D:" + File.separator + "person.ser") ; ObjectOutputStream oos = null ;
//装饰流(流)
oos = new ObjectOutputStream(new FileOutputStream(file)) ;
//实例化类
Person per = new Person("张三",30) ; oos.writeObject(per) ;//把类对象序列化
oos.close() ;
}
}
④ Java中如何实现序列化,有什么意义
序列化就是一种用来处理对象流的机制,所谓对象流也就是将对象的内容进行流化。可以对流化后的对象进行读写操作,也可将流化后的对象传输于网络之间。序列化是为了解决对象流读写操作时可能引发的问题(如果不进行序列化可能会存在数据乱序的问题)。
要实现序列化,需要让一个类实现Serializable接口,该接口是一个标识性接口,标注该类对象是可被序列化的,然后使用一个输出流来构造一个对象输出流并通过writeObject(Object)方法就可以将实现对象写出(即保存其状态);如果需要反序列化则可以用一个输入流建立对象输入流,然后通过readObject方法从流中读取对象。序列化除了能够实现对象的持久化之外,还能够用于对象的深度克隆。
⑤ Java对象怎么序列化和反序列化
importjava.io.Serializable;
/*
*NotSerializableException:未序列化异常
*
*类通过实现java.io.Serializable接口以启用其序列化功能。未实现此接口的类将无法使其任何状态序列化或反序列化。
*该接口居然没有任何方法,类似于这种没有方法的接口被称为标记接口。
*
*java.io.InvalidClassException:
*cn.itcast_07.Person;localclassincompatible:
*=-2071565876962058344,
*localclassserialVersionUID=-8345153069362641443
*
*为什么会有问题呢?
* Person类实现了序列化接口,那么它本身也应该有一个标记值。
* 这个标记值假设是100。
* 开始的时候:
* Person.class--id=100
* wirte数据:oos.txt--id=100
* read数据:oos.txt--id=100
*
* 现在:
* Person.class--id=200
* wirte数据:oos.txt--id=100
* read数据:oos.txt--id=100
*在实际开发中,可能还需要使用以前写过的数据,不能重新写入。怎么办呢?
*回想一下原因是因为它们的id值不匹配。
*每次修改java文件的内容的时候,class文件的id值都会发生改变。
*而读取文件的时候,会和class文件中的id值进行匹配。所以,就会出问题。
*但是呢,如果有办法,让这个id值在java文件中是一个固定的值,这样,你修改文件的时候,这个id值还会发生改变吗?
*不会。现在的关键是我如何能够知道这个id值如何表示的呢?
*不用担心,不用记住,也没关系,点击鼠标即可。
*难道没有看到黄色警告线吗?
*
*要知道的是:
* 看到类实现了序列化接口的时候,要想解决黄色警告线问题,就可以自动产生一个序列化id值。
* 而且产生这个值以后,我们对类进行任何改动,它读取以前的数据是没有问题的。
*
*注意:
* 一个类中可能有很多的成员变量,有些我不想进行序列化。请问该怎么办呢?
* 使用transient关键字声明不需要序列化的成员变量
*/
{
=-2071565876962058344L;
privateStringname;
//privateintage;
privatetransientintage;
//intage;
publicPerson(){
super();
}
publicPerson(Stringname,intage){
super();
this.name=name;
this.age=age;
}
publicStringgetName(){
returnname;
}
publicvoidsetName(Stringname){
this.name=name;
}
publicintgetAge(){
returnage;
}
publicvoidsetAge(intage){
this.age=age;
}
@Override
publicStringtoString(){
return"Person[name="+name+",age="+age+"]";
}
}
⑥ 关于java的序列化
那要看这个类的成员是啥样的,如果存在private成员那就没法处理了,protected和public成员可以通过继承读出,但多个类时就要继承出多个,也可通过反射机制读出,反射机制可对多个类统一处理,
⑦ 什么是java序列化,如何实现java序列化
序列化的定义:任何数据都是以二进制的形式存贮到硬盘或是在网络上传送,而Java为了能将Java对象存贮到硬盘上或在网络上传送,把Java对象转换成字节流进行传输,这个转换过程就称之为Java序列化。
Java序列化实现方式:如果需要将一个Java类序列化,这个Java类必须实现Serializable接口,这个接口中并没有需要实现的方法,只是标注这个类的对象可以被序列化。
⑧ 什么是序列化,在java中如何实现序列化
一、什么是序列化:x0dx0a序列化理解成“打碎”是可以的,不过在书本上的名词就是将对象转换成二进制。x0dx0ax0dx0a二、在java中如何实现序列化:x0dx0a首先我们要把准备要序列化类,实现 Serializabel接口x0dx0a例如:我们要Person类里的name和age都序列化x0dx0aimport java.io.Serializable;x0dx0ax0dx0apublic class Person implements Serializable { //本类可以序列化x0dx0a private String name ;x0dx0a private int age ;x0dx0a x0dx0a public Person(String name,int age){x0dx0a this.name = name ;x0dx0a this.age = age ;x0dx0a }x0dx0a public String toString(){x0dx0a return "姓名:" + this.name + ",年龄" + this.age ;x0dx0a }x0dx0a}x0dx0ax0dx0a然后:我们将name和age序列化(也就是把这2个对象转为二进制,统族理解为“打碎”)x0dx0apackage org.lxh.SerDemo;x0dx0ax0dx0aimport java.io.File;x0dx0aimport java.io.FileOutputStream;x0dx0aimport java.io.ObjectOutputStream ;x0dx0ax0dx0apublic class ObjectOutputStreamDemo { //序列化x0dx0ax0dx0a public static void main(String[] args) throws Exception {x0dx0a//序列化后生成指定文件路径x0dx0a File file = new File("D:" + File.separator + "person.ser") ; ObjectOutputStream oos = null ;x0dx0a//装饰流(流)x0dx0a oos = new ObjectOutputStream(new FileOutputStream(file)) ; x0dx0a//实例化类x0dx0a Person per = new Person("张三",30) ; oos.writeObject(per) ;//把类对象序列化x0dx0a oos.close() ;x0dx0a }x0dx0a}