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}
相关文章
|
存储 安全 Java
Java编程中的对象序列化与反序列化
【10月更文挑战第22天】在Java的世界里,对象序列化和反序列化是数据持久化和网络传输的关键技术。本文将带你了解如何在Java中实现对象的序列化与反序列化,并探讨其背后的原理。通过实际代码示例,我们将一步步展示如何将复杂数据结构转换为字节流,以及如何将这些字节流还原为Java对象。文章还将讨论在使用序列化时应注意的安全性问题,以确保你的应用程序既高效又安全。
|
JSON 前端开发 数据格式
前端的全栈之路Meteor篇(五):自定义对象序列化的EJSON介绍 - 跨设备的对象传输
EJSON是Meteor框架中扩展了标准JSON的库,支持更多数据类型如`Date`、`Binary`等。它提供了序列化和反序列化功能,使客户端和服务器之间的复杂数据传输更加便捷高效。EJSON还支持自定义对象的定义和传输,通过`EJSON.addType`注册自定义类型,确保数据在两端无缝传递。
234 1
|
存储 安全 Java
Java编程中的对象序列化与反序列化
【10月更文挑战第3天】在Java编程的世界里,对象序列化与反序列化是实现数据持久化和网络传输的关键技术。本文将深入探讨Java序列化的原理、应用场景以及如何通过代码示例实现对象的序列化与反序列化过程。从基础概念到实践操作,我们将一步步揭示这一技术的魅力所在。
|
存储 Java
Java编程中的对象序列化与反序列化
【10月更文挑战第9天】在Java的世界里,对象序列化是连接数据持久化与网络通信的桥梁。本文将深入探讨Java对象序列化的机制、实践方法及反序列化过程,通过代码示例揭示其背后的原理。从基础概念到高级应用,我们将一步步揭开序列化技术的神秘面纱,让读者能够掌握这一强大工具,以应对数据存储和传输的挑战。
|
消息中间件 存储 Java
大数据-58 Kafka 高级特性 消息发送02-自定义序列化器、自定义分区器 Java代码实现
大数据-58 Kafka 高级特性 消息发送02-自定义序列化器、自定义分区器 Java代码实现
269 3
|
存储 缓存 NoSQL
一篇搞懂!Java对象序列化与反序列化的底层逻辑
本文介绍了Java中的序列化与反序列化,包括基本概念、应用场景、实现方式及注意事项。序列化是将对象转换为字节流,便于存储和传输;反序列化则是将字节流还原为对象。文中详细讲解了实现序列化的步骤,以及常见的反序列化失败原因和最佳实践。通过实例和代码示例,帮助读者更好地理解和应用这一重要技术。
682 0
|
存储 Java
Java的对象和类的相同之处和不同之处
在 Java 中,对象和类是面向对象编程的核心。
189 19
|
存储 Java
Java编程中的对象和类
【8月更文挑战第55天】在Java的世界中,“对象”与“类”是构建一切的基础。就像乐高积木一样,类定义了形状和结构,而对象则是根据这些设计拼装出来的具体作品。本篇文章将通过一个简单的例子,展示如何从零开始创建一个类,并利用它来制作我们的第一个Java对象。准备好让你的编程之旅起飞了吗?让我们一起来探索这个神奇的过程!
114 10
|
Java
Java 对象和类
在Java中,**类**(Class)和**对象**(Object)是面向对象编程的基础。类是创建对象的模板,定义了属性和方法;对象是类的实例,通过`new`关键字创建,具有类定义的属性和行为。例如,`Animal`类定义了`name`和`age`属性及`eat()`、`sleep()`方法;通过`new Animal()`创建的`myAnimal`对象即可调用这些方法。面向对象编程通过类和对象模拟现实世界的实体及其关系,实现问题的结构化解决。
133 4
|
机器学习/深度学习 人工智能 算法
探索人工智能在医疗诊断中的应用与挑战Java编程中的对象和类:基础与实践
【8月更文挑战第27天】随着人工智能(AI)技术的飞速发展,其在医疗领域的应用日益广泛。本文深入探讨了AI技术在医疗诊断中的具体应用案例,包括图像识别、疾病预测和药物研发等方面,并分析了当前面临的主要挑战,如数据隐私、算法偏见和法规限制等。文章旨在为读者提供一个全面的视角,理解AI在改善医疗服务质量方面的潜力及其局限性。