Java的序列化

来源:互联网 发布:国产狗粮推荐 知乎 编辑:程序博客网 时间:2024/04/30 04:46

1.序列化理解成“打碎”是可以的,不过在书本上的名词就是将对象转换成二进制。一般用于将对象通过网络传输、保存成文件或写入数据库中,打碎后更易搬运或I/O;

2.序列化就是一种用来处理对象流的机制,所谓对象流也就是将对象的内容进行流化。可以对流化后的对象进行读写操作,也可将流化后的对象传输于网络之间。序列化是为了更易于对对象流进行读写操作或网络传输;

3.客户端A中的数据要转换成二级制字节,才能在网络中传输,客户端B收到后再转换成数据。这个过程就是序列化和反序列化,前者或叫写出,后者或叫读取;

4.如果要将对象通过网络传输或保存成本地文件,就必须将其序列化;

5.序列化以后对象,就变成了2进制的文件,也就是可以储存和传输。有2个好处:1) 如果是应用程序的话每次都把对象保持在文件里的话就不怕突然停电,下次启动你可以直接从文件里读出来最新的对象信息。2)RMI,EJB等实现基础就是对象的序列化;

6.如果某个类能够被序列化,其子类也可以被序列化。声明为static和transient类型的成员数据不能被序列化。因为static代表类的状态, transient代表对象的临时数据;

7.什么时候使用序列化:一:对象序列化可以实现分布式对象。主要应用例如:RMI要利用对象序列化运行远程主机上的服务,就像在本地机上运行对象时一样。二:java对象序列化不仅保留一个对象的数据,而且递归保存对象引用的每个对象的数据。可以将整个对象层次写入字节流中,可以保存在文件中或在网络连接上传递。利用对象序列化可以进行对象的"深复制",即复制对象本身及引用的对象本身。序列化一个对象可能得到整个对象序列;

8.transient(瞬态):Java的serialization提供了一种持久化对象实例的机制。当持久化对象时,如果一个用户有一些敏感信息(譬如密码,银行卡号等),为了安全起见,不希望在网络操作(主要涉及到序列化操作,本地序列化缓存也适用)中被传输,因为那样,别人可以通过反序列化知道类里面的内容,我们不想用serialization机制来保存它。为了在一个特定对象的一个域上关闭serialization,可以在这个域前加上关键字transient,用来表示一个域不是该对象串行化的一部分。当一个对象被串行化的时候,transient型变量的值不包括在串行化的表示中,然而非transient型的变量是被包括进去的;

9.当从磁盘中读出某个类的实例(反序列化)时,实际上并不会执行这个类的构造函数,而是载入了一个该类对象的持久化状态,并将这个状态赋值给该类的另一个对象;

10.化对象从磁盘中的读写: 

   ObjectInputStream in =new ObjectInputStream(                   new FileInputStream("logInfo.out"));      LoggingInfo logInfo = (LoggingInfo)in.readObject();      System.out.println(logInfo.toString());     ObjectOutputStream o = new ObjectOutputStream(                   new FileOutputStream("logInfo.out"));      o.writeObject(logInfo);      o.close(); 

11.序列化的实现:将需要被序列化的类实现Serializable接口,该接口没有需要实现的方法,implements Serializable只是为了标注该对象是可被序列化的,然后使用一个输出流(如:FileOutputStream)来构造一个ObjectOutputStream(对象流)对象,接着,使用ObjectOutputStream对象的writeObject(Object obj)方法就可以将参数为obj的对象写出(即保存其状态),要恢复的话则用输入流。也可以说,只需要两个单词,就可以搞定序列化操作:implements Serializable。见以下代码:

首先我们要把准备要序列化类,实现 Serializabel接口例如:我们要Person类里的name和age都序列化import java.io.Serializable;public class Person implements Serializable { //本类可以序列化,implements Serializable要写不然下面ObjectOutputStreamDemo.java执行报异常 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() ; }} 

 

原创粉丝点击