Java开发——31.I/O流_处理流(对象流),对象的序列化机制

本文涉及的产品
系统运维管理,不限时长
简介: 对象的序列化机制:允许把内存中的Java对象转换成和平台无关的二进制流,从而允许把这种二进制流持久地保存在磁盘上,或通过网络将这种二进制流传输到另一个网络节点(序列化);其它程序获取了这种二进制流,就可以恢复成原来的Java对象(反序列化)。

I/O流:主要操作文件内容,结合前面所学的File类,我们可以读取和写出文件,也可以修改文件的字符集编码...


处理流:

处理流就相当于外衣,每件衣服的作用不同,每个处理流的作用也不同,处理流可以实现多嵌套,即可以有多个处理流,每个处理流的功能不同!


前面已经学习过了5个处理流了,现在你对I/O的操作是不是已经烂熟于心了,今天我们将要学习的对象流,重点学习对象的序列化机制!!!


学习大纲:

image.png



对象流:

对象流和数据流类似,唯一的不同是对象流能读取/写出对象,对象流能对基本数据类型+String类型数据进行读取/写出的操作,能对保存的数据进行持久化保存到文件的操作;

对象流的强大之处,就是能把Java中的对象写入到数据源中,也能把对象从数据源中还原回来!!!


序列化:将Java对象添加到数据源中;

   标准:用ObjectOutputStream保存基本数据类型或者对象的机制;

反序列化:将Java对象从数据源中还原回来。

   标准:用ObjectInputStream读取基本数据类型或者对象的机制。

我们这里可以通俗的把数据源理解成一个哆啦A梦的转换机,可以实现大熊在任意时空中的穿梭,并保证了大熊的完整性,不会因为过程而发生变形/损失;

Java层面的理解就是:数据在序列化和反序列化的过程中,保证唯一对应,并不会因为序列化的问题而在反序列化的过程中丢失。


对象的序列化机制:

允许把内存中的Java对象转换成和平台无关的二进制流,从而允许把这种二进制流持久地保存在磁盘上,或通过网络将这种二进制流传输到另一个网络节点(序列化);其它程序获取了这种二进制流,就可以恢复成原来的Java对象(反序列化)。


序列化的好处:

可以将传入的任何实现了Serializable接口的对象转换为字节数据,使其在保存和还原的过程中可被还原!!!


序列化就是JavaEE平台的基础;RMI(Remote Method Invoke – 远程方法调用)过程的参数和返回值都必须实现的机制



序列化图解过程:

image.png


展开说明:


interfaceSerializable它里面是没有方法或者参数的,就相当于一个序列化机制的标识publicstaticfinallongserialVersionUID=xxxxxL;(自定义值)serialVersionUID用来表明类的不同版本间的兼容性。简言之,其目的是以序列化对象进行版本控制,有关各版本反序列化时是否兼容。


注意事项:

  1. 序列化的对象必须实现Serializable接口;
  2. 序列化的对象必须定义全局常量serialVersionUID;
  3. 序列化的对象中的所有属性必须全部实现序列化...
    针对第三条,就是为了预防对象中,包含其他自定类对象,但自定义类并没有实现序列化机制(也就是没有满足第1、2条);
  4. 不能序列化static和transient修饰的变量!!!
    static所属于类,并不属于对象;
    transient相当于临时变量。
  5. 基本数据类型底层都已经实现了Serializable接口,和定义了全局常量serialVersionUID,所以我们在使用的时候不需要重新定义...

image.png


//对第三条的解释publicclassPersonimplementsSerializable {
publicstaticfinallongserialVersionUID=415539532L;
Stringname;
intage;
intid;
Smilesmile;
}
publicclassSmileimplementsSerializable{
publicstaticfinallongserialVersionUID=4155569532L;
booleanstart;
}


对象流案例:

自定义对象:


publicclassPersonimplementsSerializable {
publicstaticfinallongserialVersionUID=415539532L;
Stringname;
intage;
intid;
Smilesmile;
@OverridepublicStringtoString() {
return"Person{"+"name='"+name+'\''+", age="+age+", id="+id+", smile="+smile+'}';
    }
publicPerson(Stringname, intage, intid) {
this.name=name;
this.age=age;
this.id=id;
    }
publicPerson(Stringname, intage, intid, Smilesmile) {
this.name=name;
this.age=age;
this.id=id;
this.smile=smile;
    }
publicPerson() {
    }
publicPerson(Stringname, intage) {
this.name=name;
this.age=age;
    }
}


写入/读取对象:


/*** 练习*/publicstaticvoidobjectStreamTest(Stringpath){
ObjectOutputStreamoos=null;
ObjectInputStreamois=null;
try {
oos=newObjectOutputStream(newFileOutputStream(path));
ois=newObjectInputStream(newFileInputStream(path));
oos.writeObject(newPerson("小红",28));
oos.flush();
Personperson= (Person) ois.readObject();
System.out.println(person);
        } catch (IOExceptione) {
e.printStackTrace();
        } catch (ClassNotFoundExceptione) {
e.printStackTrace();
        } finally {
if (oos!=null) {
try {
oos.close();
                } catch (IOExceptione) {
e.printStackTrace();
                }
            }
if (ois!=null) {
try {
ois.close();
                } catch (IOExceptione) {
e.printStackTrace();
                }
            }
        }
    }
//Person{name='小红', age=28, id=0, smile=null}
相关文章
|
8天前
|
Java
java代码优化:判断内聚到实体对象中和构造上下文对象传递参数
通过两个常见的java后端实例场景探讨代码优化,代码不是优化出来的,而是设计出来的,我们永远不可能有专门的时间去做代码优化,优化和设计在平时
25 15
|
2月前
|
安全 Java 编译器
Java对象一定分配在堆上吗?
本文探讨了Java对象的内存分配问题,重点介绍了JVM的逃逸分析技术及其优化策略。逃逸分析能判断对象是否会在作用域外被访问,从而决定对象是否需要分配到堆上。文章详细讲解了栈上分配、标量替换和同步消除三种优化策略,并通过示例代码说明了这些技术的应用场景。
Java对象一定分配在堆上吗?
|
2月前
|
存储 缓存 安全
🌟Java零基础:深入解析Java序列化机制
【10月更文挑战第20天】本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
37 3
|
2月前
|
存储 安全 Java
Java编程中的对象序列化与反序列化
【10月更文挑战第22天】在Java的世界里,对象序列化和反序列化是数据持久化和网络传输的关键技术。本文将带你了解如何在Java中实现对象的序列化与反序列化,并探讨其背后的原理。通过实际代码示例,我们将一步步展示如何将复杂数据结构转换为字节流,以及如何将这些字节流还原为Java对象。文章还将讨论在使用序列化时应注意的安全性问题,以确保你的应用程序既高效又安全。
|
2月前
|
存储 缓存 NoSQL
一篇搞懂!Java对象序列化与反序列化的底层逻辑
本文介绍了Java中的序列化与反序列化,包括基本概念、应用场景、实现方式及注意事项。序列化是将对象转换为字节流,便于存储和传输;反序列化则是将字节流还原为对象。文中详细讲解了实现序列化的步骤,以及常见的反序列化失败原因和最佳实践。通过实例和代码示例,帮助读者更好地理解和应用这一重要技术。
64 0
|
Java 开发工具 git
Java开发初级6.24.3
5.在Git使用过程中,进行Git配置的操作命令是哪个() A. config B. config -g C. config -a D. git config 相关知识点: 在git中,经常使用git config 命令用来配置git的配置文件,git配置级别主要有:仓库级别 local 【优先级最高】、用户级别 global【优先级次之】、系统级别 system【优先级最低】 正确答案:D 10.RDBMS是什么? A. Rela Database Management Systems B. Relational Database Management Systems C. Relation
143 0
|
SQL 前端开发 JavaScript
Java开发初级6.24.2
3.Java网站src/main/java目录保存的是什么资源? A. Java源代码文件 B. 测试代码 C. JavaScript、CSS等文件 D. 图片资源 正确答案:A 4.什么是索引Index? A. SQL数据库里的表管理工具 B. SQL数据库里的查询工具 C. SQL数据库里的目录工具 D. SQL数据库用来加速数据查询的特殊的数据结构 正确答案:D
152 0
|
Java
Java开发初级6.24.1
1.下面关于泛型的描述中错误的一项是? A. “? extends 类”表示设置泛型上限 B. “? super 类”表示设置泛型下限 C. 利用“?”通配符可以接收全部的泛型类型实例,但却不可修改泛型属性内容 D. 如果类在定义时使用了泛型,则在实例化类对象时需要设置相应的泛型类型,否则程序将无法编译通过 相关知识点: https://edu.aliyun.com/course/35 正确答案:D 2.下列选项中属于SVN中控制鉴权用户访问版本库的权限默认权限的是() A. write B. read C. none D. null 相关知识点: auth-access:取值范围为"writ
247 0
|
Java 开发工具 git
Java开发初级6.23.3
5.在Git使用过程中,进行Git配置的操作命令是哪个() A. config B. config -g C. config -a D. git config 相关知识点: 在git中,经常使用git config 命令用来配置git的配置文件,git配置级别主要有:仓库级别 local 【优先级最高】、用户级别 global【优先级次之】、系统级别 system【优先级最低】 正确答案:D 10.RDBMS是什么? A. Rela Database Management Systems B. Relational Database Management Systems C. Relation
135 0
|
SQL 前端开发 JavaScript
Java开发初级6.23.2
3.Java网站src/main/java目录保存的是什么资源? A. Java源代码文件 B. 测试代码 C. JavaScript、CSS等文件 D. 图片资源 正确答案:A 4.什么是索引Index? A. SQL数据库里的表管理工具 B. SQL数据库里的查询工具 C. SQL数据库里的目录工具 D. SQL数据库用来加速数据查询的特殊的数据结构 正确答案:D
232 0