对象的输出流:ObjectOutputStream  把对象输出到文件存储起来,我们称作为序列化
对象的输入流:ObjectInputStream   把对象从文件中读取出来,我们称作为反序列化

ObjectOutputStream
    构造方法:
        ObjectOutputStream()
            为完全重新实现 ObjectOutputStream 的子类提供一种方法,让它不必分配仅由 ObjectOutputStream 的实现使用的私有数据。
        ObjectOutputStream(OutputStream out)
            创建写入指定 OutputStream 的 ObjectOutputStream。
    一些方法:
        writeObject(Object obj)   将指定的对象写入 ObjectOutputStream。
    注意:其他的一些方法可以查看jdk文档

ObjectInputStream
    构造方法:
        ObjectInputStream()
            为完全重新实现 ObjectInputStream 的子类提供一种方式,让它不必分配仅由 ObjectInputStream 的实现使用的私有数据。
        ObjectInputStream(InputStream in)
            创建从指定 InputStream 读取的 ObjectInputStream。
    一些方法:
        readObject()    从 ObjectInputStream 读取对象。
            注意:readObject方法一次只会读取一个对象,如果想要读取多个对象需要利用EOFException
            EOFException  此异常主要被数据输入流用来表明到达流的末尾。
            其他许多输入操作返回一个特殊值表示到达流的末尾,而不是抛出异常。

        注意:其他的一些方法可以查看jdk文档
        
对象的输入输出流作用:对象的输入输出流主要的作用是用于读写对象的信息。对象一但写到文件上那么就可以做到持久化了

对象的输入输出流的使用步骤:
    1.被序列化对象的所属类必须实现Serializable(标识)接口
    2.给被序列化对象的所属类指定SerialVersionUID值(可选)
    3.被序列化对象的所属类的某些隐秘成员要使用transient修饰(可选)

对象输入输出流要注意的细节:
    1.如果对象需要被写出到文件上,那么对象所属的类必须要实现Serializable接口。Serializable只是一个没有任何方法的接口,一般这样的接口我们称作为标识接口
    2.对象的反序列化创建对象的时候并不会调用构造方法
    3.SerialVersionUID适用于记录被写入对象所属类的版本信息的    ,ServialVersionUID这个数字是通过一个类名、成员、包名、工程名算出来的一个数字
    4.如果反序列化的时候,ServialVersionUID不一致,那么会反序列化失败,也就是接受ObjectOutputStream的writeObject方法的返回值的所属类的版本信息一定要跟存入文本时的对象所属类的版本信息一样(类名、成员、包名、工程名一样)
    5.如果序列化和反序列化的时候可能会修改类的成员,那么最好一开始就给这个类指定一个ServialVersionUID,那么当我们把对象存入文本中的时候jvm不会自己再算ServialVersionUID。这个就可以保证接受对象和存入对象的所属类的版本信息一样,我们也就可以修改成员了(我自己偏向于指定,毕竟有时候自己并不知道会不会修改)
    6.如果一个对象某些数据不想被序列化到硬盘上,那么对象的所属类的成员变量可以使用transient(中文:透明)修饰,这样就可以保证被修饰的数据就不会序列化到硬盘上,当然反序列的时候也得不到这个数据
    7.如果要被序列化对象所属类的内部维护了另一个类的引用,那么另一个类也需要实现Serializable接口,当然版本信息也需要相同

下面是一些实例:

class Work implements Serializable{

    private static final long serialVersionUID = 1L;
String workname;
double money; public Work(String workname , double money) {
this.workname = workname;
this.money = money;
}
} class People implements Serializable{
//指定版本编号
private static final long serialVersionUID = 1L;
transient int card; //身份证涉及隐私我们可以使用transient修饰,不序列化到硬盘中
String name;
int age; //维护一个另一个类的引用
Work work; public People(int card ,String name , int age,Work work) {
this.card = card;
this.name = name;
this.age = age;
this.work = work;
} //自定义输出格式
@Override
public String toString() { return "{省份证编号:"+this.card+" 姓名:"+this.name+" 年龄:"+this.age+" 工作:"+work.workname+" 工资:"+this.work.money+"}";
}
} public class Demo1 {
public static void main(String[] args) throws IOException, ClassNotFoundException {
writeObject();
readObject();
}
//序列化,把对象存入硬盘中
public static void writeObject() throws IOException {
//找到目标文件
File file = new File("D:\\新建文件夹\\a.txt");
//建立数据传输通道
FileOutputStream fileOutputStream = new FileOutputStream(file);
//建立对象的传输通道
ObjectOutputStream objectOutputStream = new ObjectOutputStream(fileOutputStream);
//序列化对象,写入硬盘
objectOutputStream.writeObject(new People(1001,"张三",18,new Work("打酱油",5000.0)));
objectOutputStream.writeObject(new People(1002,"李四",19,new Work("收酱油",5000.0)));
//关闭资源
objectOutputStream.close();//相当于fileOutputStream.close()
} //反序列化
public static void readObject() throws IOException{
//找到目标文件
File file = new File("D:\\新建文件夹\\a.txt");
//建立数据传输通道
FileInputStream fileInputStream = new FileInputStream(file);
//建立对象的传输通道
ObjectInputStream objectInputStream = new ObjectInputStream(fileInputStream);
//读取文件
//EOFException 此异常主要被数据输入流用来表明到达流的末尾。
//注意,其他许多输入操作返回一个特殊值表示到达流的末尾,而不是抛出异常。
People p;
while(true) {
try {
p = (People)objectInputStream.readObject();
System.out.println(p);
} catch(EOFException e) {
break;
}catch(ClassNotFoundException e) {
break;
}
}
objectInputStream.close();//相当于fileInputStream.close()
}
}

文件被序列化到文本中存储的内容

文件被反序列化

从这里我们可以发现,我们使用transient修饰的card没有被写入和读取出来(0是默认的初始值)

71 Serializable(序列化和反序列化)的更多相关文章

  1. Java 之 Serializable 序列化和反序列化的概念,作用的通俗易懂的解释

    遇到这个 Java Serializable 序列化这个接口,我们可能会有如下的问题a,什么叫序列化和反序列化b,作用.为啥要实现这个 Serializable 接口,也就是为啥要序列化c,seria ...

  2. [转]Java 之 Serializable 序列化和反序列化的概念,作用的通俗易懂的解释

    原文地址:https://blog.csdn.net/qq_27093465/article/details/78544505 遇到这个 Java Serializable 序列化这个接口,我们可能会 ...

  3. 黑马程序员_Java基础:序列化(Serializable)与反序列化

    ------- android培训.java培训.期待与您交流! ---------- 在学习IO中的ObjectOutputStream和ObjectInputStream时,会涉及到序列化和反序列 ...

  4. Java序列化与反序列化(Serializable)

    Java序列化与反序列化(Serializable) 特别注意: 1.要序列化的类必须实现Serializable借口 2.在反序列化(读取对象)的时候必须额外捕获EOFException 3.序列化 ...

  5. 序列化与反序列化总结(Serializable和Parcelable)

    序列化是指将对象的状态信息转换为可以存储或传输的形式的过程. 在Java中创建的对象,只要没有被回收就可以被复用,但是,创建的这些对象都是存在于JVM的堆内存中,JVM处于运行状态时候,这些对象可以复 ...

  6. 序列化、反序列化(Serializable特性)

    //需要被实例化的类 using System.Collections; using UnityEngine; [Serializable] public class SerializableClas ...

  7. 使用Serializable接口进行JAVA的序列化和反序列化

    OBJECT STREAMS – SERIALIZATION AND DESERIALIZATION IN JAVA EXAMPLE USING SERIALIZABLE INTERFACE Hite ...

  8. Serializable 接口与 Java 序列化与反序列化

    0. 序列化的意义 从内存到本地即为本地化或者在网络中进行传输,或叫序列化,持久化. 某 Java 类实现 Serializable 接口的目的是为了可持久化(简单理解为本地化),比如网络传输或本地存 ...

  9. Java 对象序列化和反序列化 (实现 Serializable 接口)

    序列化和反序列化的概念 把对象转换为字节序列的过程称为对象的序列化.  把字节序列恢复为对象的过程称为对象的反序列化. 对象的序列化主要有两种用途: 1) 把对象的字节序列永久地保存到硬盘上,通常存放 ...

随机推荐

  1. Vue路由组件vue-router

    一.路由介绍 Creating a Single-page Application with Vue + Vue Router is dead simple. With Vue.js, we are ...

  2. JavaSE---用户交互---获取键盘输入

    1.概述 1.1 JDK1.5提供了Scanner类,用来获取键盘输入: 1.2 Scanner类是   一个基于正则表达式的文本扫描器,可以从文件.输入流.字符串中解析出基本类型值.字符串值: 1. ...

  3. SQL Server 管理套件(SSMS)

    SQL Server 管理套件(SSMS) 当您按照之前章节的步骤顺利安装完 SQL Server 2014 后,要做的第一件事就是需要打开 SQL Server 管理套件,并且要知道怎样去使用它. ...

  4. apue 第6章 系统数据文件和信息

    在给出用户登录名或数值用户ID后,这两个函数就能查看相关项. #include <sys/types.h> #include <pwd.h> struct passwd *ge ...

  5. LCD驱动程序架构和分析

    一.LCD驱动程序架构 1.裸机驱动代码分析 ①LCD初始化:控制器初始化,端口初始化,指明帧缓冲 ②LCD图形显示:将图形数据写入帧缓冲 void lcd_init() { lcd_port_ini ...

  6. 线程类中使用spring注解报空指针异常

    springboot项目开发中,作为服务端,实现了线程类,在此类中添加spring注解@Source注入的service,报空指针异常. 查原因后,发现是线程中,不支持spring注解,因为sprin ...

  7. jquery中attr方法和prop方法的区别

    关于checked的属性,最重要的概念就是你要记住,它跟checked的状态值是毫无关系的,设置checked = "checked"或者checked = "true& ...

  8. 驱动中PAGED_CODE的作用

    参考:http://blog.csdn.net/broadview2006/article/details/4171397 里面的内容出自<Windows内核情景分析> 简而言之,Wind ...

  9. 2019牛客多校第⑨场D Knapsack Cryptosystem(折半搜索)

    原题:https://ac.nowcoder.com/acm/contest/889/D 题意: 给定大小为n(<=36)的集合a,整数s,求a的一个和为s的子集(有且只有一个) 思路: 直接搜 ...

  10. 高级UI晋升之自定义View实战(五)

    更多Android高级架构进阶视频学习请点击:https://space.bilibili.com/474380680本篇文章将从自定义View利器Canvas和Paint来进行详解 一.Canvas ...