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}
相关文章
|
9天前
|
安全 Java 编译器
Java对象一定分配在堆上吗?
本文探讨了Java对象的内存分配问题,重点介绍了JVM的逃逸分析技术及其优化策略。逃逸分析能判断对象是否会在作用域外被访问,从而决定对象是否需要分配到堆上。文章详细讲解了栈上分配、标量替换和同步消除三种优化策略,并通过示例代码说明了这些技术的应用场景。
Java对象一定分配在堆上吗?
|
11天前
|
XML 安全 Java
Java反射机制:解锁代码的无限可能
Java 反射(Reflection)是Java 的特征之一,它允许程序在运行时动态地访问和操作类的信息,包括类的属性、方法和构造函数。 反射机制能够使程序具备更大的灵活性和扩展性
19 5
Java反射机制:解锁代码的无限可能
|
5天前
|
安全 IDE Java
Java反射Reflect机制详解
Java反射(Reflection)机制是Java语言的重要特性之一,允许程序在运行时动态地获取类的信息,并对类进行操作,如创建实例、调用方法、访问字段等。反射机制极大地提高了Java程序的灵活性和动态性,但也带来了性能和安全方面的挑战。本文将详细介绍Java反射机制的基本概念、常用操作、应用场景以及其优缺点。 ## 基本概念 ### 什么是反射 反射是一种在程序运行时动态获取类的信息,并对类进行操作的机制。通过反射,程序可以在运行时获得类的字段、方法、构造函数等信息,并可以动态调用方法、创建实例和访问字段。 ### 反射的核心类 Java反射机制主要由以下几个类和接口组成,这些类
15 2
|
8天前
|
存储 安全 Java
🌟Java零基础-反序列化:从入门到精通
【10月更文挑战第21天】本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
37 5
|
10天前
|
存储 缓存 安全
🌟Java零基础:深入解析Java序列化机制
【10月更文挑战第20天】本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
18 3
|
10天前
|
安全 Java UED
深入理解Java中的异常处理机制
【10月更文挑战第25天】在编程世界中,错误和意外是不可避免的。Java作为一种广泛使用的编程语言,其异常处理机制是确保程序健壮性和可靠性的关键。本文通过浅显易懂的语言和实际示例,引导读者了解Java异常处理的基本概念、分类以及如何有效地使用try-catch-finally语句来处理异常情况。我们将从一个简单的例子开始,逐步深入到异常处理的最佳实践,旨在帮助初学者和有经验的开发者更好地掌握这一重要技能。
16 2
|
12天前
|
Java 数据库连接 开发者
Java中的异常处理机制####
本文深入探讨了Java语言中异常处理的核心概念,通过实例解析了try-catch语句的工作原理,并讨论了finally块和throws关键字的使用场景。我们将了解如何在Java程序中有效地管理错误,提高代码的健壮性和可维护性。 ####
|
11天前
|
存储 运维 Java
💻Java零基础:深入了解Java内存机制
【10月更文挑战第18天】本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
23 1
|
6天前
|
Java 开发者
深入理解Java异常处理机制
【10月更文挑战第29天】在Java的世界中,异常处理如同生活的调味品,不可或缺。它确保了程序在遇到错误时不会崩溃,而是优雅地继续运行或者给出提示。本文将带你领略异常处理的奥秘,从基础的try-catch语句到高级的自定义异常,让你在面对程序中的各种“意外”时,能够从容应对。
|
8天前
|
SQL Java
探索Java中的异常处理机制
【10月更文挑战第26天】 在本文中,我们将深入探讨Java编程语言的异常处理机制。通过分析不同类型的异常、异常的捕获与抛出方式,以及如何自定义异常类,读者将能够更好地理解并应用Java中的异常处理机制来提高代码的健壮性和可读性。
17 0