Java中如何实现对象的序列化和反序列化?(两种方法)

本篇文章给大家带来的内容是关于java中如何实现对象的序列化和反序列化?(两种方法),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

引言:

序列化是将对象的状态信息转换为可以存储或传输的形式的过程,在序列化期间,对象将其带你过去的状态写入到临时或持储存区,反序列化就是重新创建对象的过程,此对象来自于临时或持久储存区。

序列化的作用:

就好比如存储数据到数据库,将一些数据持久化到数据库中,而有时候需要将对象持久化,虽然说将对象状态持久化的方式有很多,但是java给我们提供了一种很便捷的方式,那就是序列化,序列化可以实现对象到文件之间的直接转换,实现细节对我们隐藏。

具体的三种用途:

将对象的状态信息持久化保存到硬盘上

立即学习“Java免费学习笔记(深入)”;

将对象信息在网络上传输

深度克隆(就是序列化后再反序列化)

序列猴子开放平台 序列猴子开放平台

具有长序列、多模态、单模型、大数据等特点的超大规模语言模型

序列猴子开放平台 0 查看详情 序列猴子开放平台

方式一:实现Serializable接口,通过序列化流

实现Serializable接口,通过ObjectOutputStream和ObjectInputStream将对象序列化和反序列化。

import java.io.*;public class User implements Serializable {    private static final long serialVersionUID = 1L;    private String name;    private int age;    public User(String name, int age) {        this.name = name;        this.age = age;    }    @Override    public String toString() {        return "User{" +                "name='" + name + ''' +                ", age=" + age +                '}';    }    public static void main(String[] args) throws IOException, ClassNotFoundException {//        User user = new User("gol",22);//        ByteArrayOutputStream bo = new ByteArrayOutputStream();//        ObjectOutputStream oo = new ObjectOutputStream(bo);//        oo.writeObject(user);//序列化.user写入字节数组流中//        ByteArrayInputStream bi = new ByteArrayInputStream(bo.toByteArray());//        ObjectInputStream oi = new ObjectInputStream(bi);//        User userSer = (User) oi.readObject();//反序列化//        System.out.println(userSer);        User user = new User("gol",22);        FileOutputStream fos = new FileOutputStream("a.txt");        ObjectOutputStream oo = new ObjectOutputStream(fos);        oo.writeObject(user);//序列化.user写入文件中        FileInputStream fis = new FileInputStream("a.txt");        ObjectInputStream oi = new ObjectInputStream(fis);        User userSer = (User) oi.readObject();//反序列化        System.out.println(userSer);        oi.close();        fis.close();        oo.close();        fos.close();    }}

方式二:实现Externalizable接口,重写writeExternal和readExternal方法

Externalizable接口继承了Serializable接口,替我们封装了两个方法,一个用于序列化,一个用于反序列化。这种方式是将属性序列化,注意这种方式transient修饰词将失去作用,也就是说被transient修饰的属性,只要你在writeExternal方法中序列化了该属性,照样也会得到序列化。

import java.io.*;public class User implements Externalizable {    private static final long serialVersionUID = 1L;    private  String name;    private  int age;    public User() {    }    public User(String name, int age) {        this.name = name;        this.age = age;    }    @Override    public String toString() {        return "User{" +                "name='" + name + ''' +                ", age=" + age +                '}';    }    @Override    public void writeExternal(ObjectOutput out) throws IOException {        out.writeObject(this.name);//将属性分别序列化        out.writeObject(this.age);    }    @Override    public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException {        this.name=(String)in.readObject();//反序列化属性        this.age=(int)in.readObject();    }    public static void main(String[] args) throws IOException, ClassNotFoundException {        FileOutputStream fos = new FileOutputStream("a.txt");        ObjectOutputStream oo = new ObjectOutputStream(fos);        FileInputStream fis = new FileInputStream("a.txt");        ObjectInputStream oi = new ObjectInputStream(fis);        User user = new User("gol",19);        user.writeExternal(oo);//序列化        User userEnr = new User();        userEnr.readExternal(oi);//反序列化        System.out.println(userEnr);        oi.close();        fis.close();        oo.close();        fos.close();    }}

总结:

注意以下三点:

Serializable接口是标记接口,是个空接口,用于标识该类可以被序列化。

transient是属性修饰符,被其修饰的属性将不会被序列化,但是使用方式二的话,明确写明该属性序列化同样可以得到序列化。

serialVersionUID属性是类的序列化标识ID,若序列化的对象和反序列化的对象其serialVersionUID属性不一样则会报错。

以上就是Java中如何实现对象的序列化和反序列化?(两种方法)的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/381477.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月6日 11:31:10
下一篇 2025年11月6日 11:32:20

相关推荐

  • Go语言中嵌入式类型方法覆盖与显式调用

    本教程深入探讨go语言中嵌入式类型的方法覆盖机制。当外部结构体定义了与嵌入类型同名的方法时,会发生方法覆盖(shadowing)。文章将通过具体代码示例,详细阐述go如何处理这种情况,并指导开发者如何在方法被覆盖后,显式地调用嵌入类型(“基类”)的原始方法,从而有效利用go的组合特性。 1. Go语…

    2025年12月16日
    000
  • 理解Go语言的可见性规则:包名与导出标识符的区别

    go语言通过标识符的首字母大小写来控制其可见性:大写表示导出(public),可在包外部访问;小写表示未导出(private),只能在包内部访问。这一规则适用于函数、类型、变量、结构体字段等。需要注意的是,包名本身通常是小写,而其内部的导出成员(如list.list中的list)则遵循大写规则,这与…

    2025年12月16日
    000
  • Go语言结构体初始化:使用构造函数模式传递字段参数

    本文深入探讨了在go语言中初始化结构体时,如何通过函数优雅地传递字段参数。我们将介绍一种推荐的“构造函数”模式,该模式通过定义一个以`new`开头的函数来接收结构体字段的独立参数,并在函数内部完成结构体的创建、初始化及潜在的额外逻辑处理,最终返回结构体实例的指针。这种方法避免了直接传递整个结构体字面…

    2025年12月16日
    000
  • Go语言并发编程:深入理解空结构体struct{}与通道同步机制

    本教程深入探讨go语言中空结构体struct{}的独特之处及其在并发编程中的核心应用。我们将解析struct{}作为零内存占用的信号类型,如何在通道中实现高效的事件通知。同时,文章还将详细阐述如何利用通道接收操作(如 Go语言中的空结构体struct{}及其应用 在Go语言中,struct{}是一个…

    2025年12月16日
    000
  • 如何在Golang中捕获切片操作异常_Golang切片操作错误处理详解

    答案:Go语言中切片操作越界会引发panic,需通过defer和recover捕获,但更推荐预先检查边界。示例包括索引越界、空切片访问等场景,应使用返回(value, bool)或(value, error)的封装函数进行安全处理,避免依赖panic/recover机制,仅在必要时用其作为兜底保护。…

    2025年12月16日
    000
  • 管理临时文件下载:用户下载完成后删除生成的ZIP文件

    本文旨在探讨在web应用中,用户下载生成的zip文件后,如何安全有效地从服务器删除这些临时文件。文章将分析直接删除的局限性,并详细介绍通过客户端回调机制配合服务器端api实现文件删除的进阶方案,同时提供代码示例和最佳实践,确保文件管理的健壮性。 在Web开发中,为用户动态生成并提供文件下载是一个常见…

    2025年12月16日
    000
  • Go语言中空结构体(struct{})与并发同步机制深度解析

    本文深入探讨go语言中空结构体(`struct{}`)的独特之处及其在并发编程中的核心作用。我们将解析其零内存占用特性、作为通道类型进行协程间信号传递的机制,以及如何利用它高效地实现并发任务的等待与同步。此外,文章还将触及空结构体在go语言设计中的其他高级应用。 一、理解Go语言中的空结构体 str…

    2025年12月16日
    000
  • 应对百万级突发请求:Go语言异步处理与队列策略

    本文旨在探讨如何高效处理每分钟高达数百万次的突发性高并发请求,并将其异步持久化至数据库。核心策略是前端快速响应、最小化处理,并将请求数据通过显式队列卸载至后台工作者进行批量数据库写入,以满足低延迟响应和高吞吐量的需求。文章将重点分析资源限制、显式队列管理、语言选择(go vs. node.js)及监…

    2025年12月16日
    000
  • Go与Node.js应对高并发突发请求的后端架构指南

    本文旨在探讨Go和Node.js在处理极端高并发突发流量场景下的后端服务优化策略。核心思想是通过前端快速响应和后端异步处理,结合显式队列管理、严格的资源限制及有效的系统监控,以最小化突发负载期间的开销。文章将重点分析内存管理、技术选型(尤其强调Go的优势)及可观测性,为构建高性能、高可用的服务提供指…

    2025年12月16日
    000
  • 如何优雅地处理用户下载后生成的临时文件

    本文探讨了在Web应用中管理用户下载后临时生成文件的高效策略。针对传统文件下载场景,文章介绍了通过客户端JavaScript库结合服务器端API实现文件下载完成后的异步删除机制。此外,也提及了直接删除文件的基本方法及其局限性,并强调了在文件管理中应考虑的错误处理、安全性和定期清理等最佳实践。 在开发…

    2025年12月16日
    000
  • Web应用中下载后自动删除临时文件的策略

    在web应用中,管理用户下载后生成的临时文件是一项常见挑战。由于http协议的无状态特性,服务器难以直接感知用户下载完成的时机。本文将深入探讨如何在用户完成文件下载后,通过结合客户端回调机制与服务器端api,实现对临时文件的安全、及时删除。内容涵盖基础文件删除操作、客户端检测下载完成的方法以及相关安…

    2025年12月16日
    000
  • Go语言并发编程中空结构体struct{}的巧妙应用与同步机制解析

    本文深入探讨go语言中空结构体`struct{}`的特性及其在并发编程中的核心作用。我们将解析`struct{}`作为一种零内存占用类型,如何通过通道(channel)进行高效的信号传递,实现goroutine之间的同步与协作。文章将通过示例代码详细阐述`struct{}`在等待goroutine完…

    2025年12月16日
    000
  • 高并发突发请求处理策略:Go与Node.js的权衡与实践

    本文探讨了在高并发突发请求场景下,如何高效处理每秒数百万次请求的策略。核心思想是在请求高峰期尽可能减少同步操作,通过引入限制、显式队列和异步处理机制,将数据快速接收并缓冲,随后由后台工作者异步持久化到数据库。文章对比了Go和Node.js在此类场景下的优劣,并强调了系统可观测性的重要性。 在现代We…

    2025年12月16日
    000
  • Go与Node.js在高并发突发请求处理中的策略与实践

    本文深入探讨了在高并发突发请求场景下,如何通过前端缓冲、内存队列、异步处理和精细化资源管理来优化系统性能。重点比较了go和node.js在处理此类负载时的优劣,强调了显式队列管理和可观测性的重要性。文章旨在提供一套高效、可控的解决方案,以应对瞬时高负载并确保数据可靠性。 在现代Web应用开发中,处理…

    2025年12月16日
    000
  • Web应用中用户下载后自动删除服务器生成文件的策略与实现

    在web应用中,管理用户下载后生成的临时文件是一个常见挑战。本文将探讨如何在用户完成文件下载后,安全、高效地从服务器删除这些临时文件。我们将介绍基础的服务器端文件删除方法,并重点讲解如何通过结合客户端下载事件监听(例如使用ajax文件下载库)与服务器端api调用,实现精确的文件删除时机控制,确保资源…

    2025年12月16日
    000
  • Go语言中struct{}的妙用:高效信号传递与并发同步

    `struct{}`是go语言中一种特殊的空结构体类型,它不占用任何内存空间,是实现高效信号传递和并发同步的理想选择。在并发编程中,尤其是在使用通道进行goroutine间的协调时,`struct{}`常被用作通道的元素类型,其发送和接收操作本身即代表一个事件信号,而非传递具体数据。本文将深入探讨`…

    2025年12月16日
    000
  • 高效管理用户下载后临时文件的删除策略

    在Web应用中,管理用户下载后生成的临时文件(如ZIP压缩包)是一个常见挑战。本文将探讨两种主要策略:一是服务器端直接删除,但其难以准确判断下载完成时机;二是利用客户端AJAX文件下载库,通过回调机制在下载成功后通知服务器进行删除。文章将提供具体代码示例和注意事项,帮助开发者实现安全、高效的临时文件…

    2025年12月16日
    000
  • 如何使用Golang的接口类型_Golang接口定义与实现规则详解

    Go接口通过隐式实现方法提供多态性,无需显式声明;只要类型实现接口所有方法即可赋值使用,支持值或指针接收者,结合空接口与类型断言可处理任意类型。 在Golang中,接口(interface)是一种定义行为的方式,它允许类型通过实现方法来满足接口。Go语言的接口是隐式实现的,不需要显式声明某个类型实现…

    2025年12月16日
    000
  • Golang HTTP 服务器如何处理文件请求_Golang 文件服务实现与性能优化

    Go语言通过net/http包可轻松实现高效文件服务器。使用http.FileServer结合http.StripPrefix能快速搭建静态文件服务,将指定目录映射到URL路径。为增强控制力,可自定义Handler函数,添加缓存头、安全头及内容类型判断,提升用户体验与安全性。性能优化方面,建议启用G…

    2025年12月16日
    000
  • Go语言的泛型实现:利用代码生成工具gen

    Go语言以其简洁、高效和并发特性而闻名,但在其发展初期,一直缺乏对泛型(Generics)或模板(Templates)的原生支持。这导致在构建通用数据结构(如列表、栈、队列等)时,开发者通常依赖于interface{}类型来存储任意数据。虽然interface{}提供了极大的灵活性,允许在集合中存储…

    2025年12月16日
    000

发表回复

登录后才能评论
关注微信