当前位置: 首页 > news >正文

通过示例解释序列化和反序列化-Java

序列化和反序列化是Java(以及通常的编程)中涉及将对象转换为字节流,以及反之的过程。当你需要传输或存储对象的状态时特别有用,比如将其通过网络发送或持久化到文件中。

序列化:

  • 定义:序列化是将对象的状态(字段和数据)转换为字节流的过程。
  • 目的:它允许保存对象的状态,以便以后可以重建它。
  • Java接口:SerializableJava中的接口是一个标记接口,表示一个类可以被序列化。

反序列化:

  • 定义:反序列化是从字节流重建对象的过程。
  • 目的:它允许从保存的状态重新创建原始对象。
  • Java 接口:实现的类Serializable应该被反序列化。

用途和实时应用:

  • 网络通讯:

  • 用例:当需要通过网络在不同应用程序或系统之间发送对象时。

  • 示例:客户端-服务器应用程序,其中对象在客户端和服务器之间发送。

import java.io.*;
import java.net.*;public class User implements Serializable {private String username;private transient String password; // Transient fields are not serialized// Constructors, getters, setters...public static void main(String[] args) {// Serialization (Client Side)try (Socket socket = new Socket("server_address", 12345);ObjectOutputStream out = new ObjectOutputStream(socket.getOutputStream())) {User user = new User("john_doe", "password123");out.writeObject(user);System.out.println("User object sent to server");} catch (IOException e) {e.printStackTrace();}// Deserialization (Server Side)try (ServerSocket serverSocket = new ServerSocket(12345);Socket clientSocket = serverSocket.accept();ObjectInputStream in = new ObjectInputStream(clientSocket.getInputStream())) {User receivedUser = (User) in.readObject();System.out.println("Received User object: " + receivedUser);} catch (IOException | ClassNotFoundException e) {e.printStackTrace();}}
}

持久化:

  • 用例:将对象的状态存储在文件或数据库中,以便以后检索。
  • 示例:将用户偏好或游戏状态保存在文件中。
import java.io.*;public class UserPreferences implements Serializable {private String theme;private int fontSize;// Constructors, getters, setters...public static void main(String[] args) {// Serialization (Save Preferences)try (ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream("user_preferences.ser"))) {UserPreferences preferences = new UserPreferences("dark", 16);out.writeObject(preferences);System.out.println("User preferences saved to file");} catch (IOException e) {e.printStackTrace();}// Deserialization (Load Preferences)try (ObjectInputStream in = new ObjectInputStream(new FileInputStream("user_preferences.ser"))) {UserPreferences loadedPreferences = (UserPreferences) in.readObject();System.out.println("Loaded User preferences: " + loadedPreferences);} catch (IOException | ClassNotFoundException e) {e.printStackTrace();}}
}

缓存:

  • 用例:将对象存储在缓存中,以便快速检索而无需重新创建它们。
  • 示例:缓存频繁使用的数据库查询结果。
import java.io.*;
import java.util.HashMap;
import java.util.Map;public class CacheManager implements Serializable {private Map<String, Object> cache = new HashMap<>();// Methods to put, get, and manage the cache...public static void main(String[] args) {// Serialization (Save Cache)try (ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream("cache.ser"))) {CacheManager cacheManager = new CacheManager();cacheManager.put("queryResult1", /* database query result */);cacheManager.put("queryResult2", /* another query result */);out.writeObject(cacheManager);System.out.println("Cache saved to file");} catch (IOException e) {e.printStackTrace();}// Deserialization (Load Cache)try (ObjectInputStream in = new ObjectInputStream(new FileInputStream("cache.ser"))) {CacheManager loadedCacheManager = (CacheManager) in.readObject();System.out.println("Loaded Cache: " + loadedCacheManager);} catch (IOException | ClassNotFoundException e) {e.printStackTrace();}}
}

消息队列:

  • 用例:在不同组件或微服务之间传递对象。
  • 示例:使用消息队列在分布式系统的不同部分之间发送对象。
import java.io.*;
import java.util.Queue;
import java.util.concurrent.ArrayBlockingQueue;public class MessageQueue implements Serializable {private Queue<String> messages = new ArrayBlockingQueue<>(10);// Methods to add, retrieve, and manage messages...public static void main(String[] args) {// Serialization (Save Message Queue)try (ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream("message_queue.ser"))) {MessageQueue messageQueue = new MessageQueue();messageQueue.addMessage("Message1");messageQueue.addMessage("Message2");out.writeObject(messageQueue);System.out.println("Message Queue saved to file");} catch (IOException e) {e.printStackTrace();}// Deserialization (Load Message Queue)try (ObjectInputStream in = new ObjectInputStream(new FileInputStream("message_queue.ser"))) {MessageQueue loadedMessageQueue = (MessageQueue) in.readObject();System.out.println("Loaded Message Queue: " + loadedMessageQueue);} catch (IOException | ClassNotFoundException e) {e.printStackTrace();}}
}

远程方法调用(RMI):

  • 用例:像调用本地方法一样在远程对象上调用方法。
  • 示例:分布式应用程序中,一个机器上的对象需要调用另一个机器上对象的方法。
import java.rmi.*;
import java.rmi.registry.*;public interface RemoteCalculator extends Remote {int add(int a, int b) throws RemoteException;// Other remote methods...
}public class CalculatorImpl implements RemoteCalculator {public int add(int a, int b) throws RemoteException {return a + b;}// Other method implementations...
}public class RmiServer {public static void main(String[] args) {try {RemoteCalculator calculator = new CalculatorImpl();Registry registry = LocateRegistry.createRegistry(1099);Naming.rebind("CalculatorService", calculator);System.out.println("RMI Server is running...");} catch (Exception e) {e.printStackTrace();}}
}public class RmiClient {public static void main(String[] args) {try {RemoteCalculator calculator = (RemoteCalculator) Naming.lookup("rmi://localhost/CalculatorService");int result = calculator.add(5, 10);System.out.println("Result from RMI server: " + result);} catch (Exception e) {e.printStackTrace();}}
}

总之,在Java中,序列化涉及将对象转换为字节流,从而实现其存储或传输;而反序列化则从字节流重构原始对象。这些过程对于诸如将对象状态保存到文件、通过网络发送对象或将数据持久化到数据库等任务至关重要,确保数据能够轻松存储、传输和随后重建。

相关文章:

通过示例解释序列化和反序列化-Java

序列化和反序列化是Java&#xff08;以及通常的编程&#xff09;中涉及将对象转换为字节流&#xff0c;以及反之的过程。当你需要传输或存储对象的状态时特别有用&#xff0c;比如将其通过网络发送或持久化到文件中。 序列化&#xff1a; 定义&#xff1a;序列化是将对象的状…...

k8s源码阅读环境配置

源码阅读环境配置 k8s代码的阅读可以让我们更加深刻的理解k8s各组件的工作原理&#xff0c;同时提升我们Go编程能力。 IDE使用Goland&#xff0c;代码阅读环境需要进行如下配置&#xff1a; 从github上下载代码&#xff1a;https://github.com/kubernetes/kubernetes在GOPATH目…...

Java JDBC整合(概述,搭建,PreparedStatement和Statement,结果集处理)

一、JDBC的概述&#xff1a; JDBC&#xff1a;是一种执行sql语句的Java APL&#xff0c;可以为多种关系类型数据库提供统一访问&#xff0c;它由一组用Java语言编写的类和接口组成。有了JDBC&#xff0c;Java人员只需要编写一次程序就可以访问不同的数据库。 JDBC APL&#xf…...

Nginx 负载均衡集群 节点健康检查

前言 正常情况下&#xff0c;nginx 做反向代理负载均衡的话&#xff0c;如果后端节点服务器宕掉的话&#xff0c;nginx 默认是不能把这台服务器踢出 upstream 负载集群的&#xff0c;所以还会有请求转发到后端的这台服务器上面&#xff0c;这样势必造成网站访问故障 注&#x…...

uniapp 多轴图,双轴图,指定哪几个数据在哪个轴上显示

这里使用的在这里导入&#xff0c; 秋云 ucharts echarts 高性能跨全端图表组件 - DCloud 插件市场 这里我封装成一个组件&#xff0c;自适应的&#xff0c;可以直接复制到自己的项目中 <template><qiun-data-charts type"mix":opts"opts":cha…...

Kotlin 协程 supervisorScope {} 运行崩溃解决

前言 简单介绍supervisorScope函数&#xff0c;它用于创建一个使用了 SupervisorJob 的 coroutineScope&#xff0c; 该作用域的特点&#xff1a;抛出的异常&#xff0c;不会 连锁取消 同级协程和父协程。 看过很多 supervisorScope {} 文档的使用&#xff0c;我照抄一摸一样…...

【Spring 篇】JdbcTemplate:轻松驾驭数据库的魔法工具

欢迎来到数据库的奇妙世界&#xff0c;在这里&#xff0c;我们将一同揭开Spring框架中JdbcTemplate的神秘面纱。JdbcTemplate是Spring提供的一个简化数据库操作的工具&#xff0c;它为我们提供了一种轻松驾驭数据库的魔法。本篇博客将详细解释JdbcTemplate的基本使用&#xff0…...

Web开发SpringBoot SpringMVC Spring的学习笔记(包含开发常用工具类)

开发框架学习笔记 一.Spring SpringMVC SpringBoot三者的联系SpringMVC工作原理 二.SpringBoot的学习2.1 注解2.1.1 SpringBoot的核心注解2.1.2 配置导入注解(简化Spring配置写XML的痛苦)Configuration和Bean(人为注册Spring 的 Bean)Import(补)ImportResource(补)AutowiredQua…...

微服务下的SpringSecurity认证端

从三板斧开始微服务下的SpringSecurity开始 一、引入组件包 <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-oauth2</artifactId> </dependency> 二、创建适配器 AuthorizationServerConfig…...

苹果电脑菜单栏应用管理软件Bartender 4 mac软件特点

Bartender mac是一款可以帮助用户更好地管理和组织菜单栏图标的 macOS 软件。它允许用户隐藏和重新排列菜单栏图标&#xff0c;从而减少混乱和杂乱。 Bartender mac软件特点 菜单栏图标隐藏&#xff1a;Bartender 允许用户隐藏菜单栏图标&#xff0c;只在需要时显示。这样可以…...

笙默考试管理系统-MyExamTest----codemirror(65)

笙默考试管理系统-MyExamTest----codemirror&#xff08;65&#xff09; 目录 一、 笙默考试管理系统-MyExamTest----codemirror 二、 笙默考试管理系统-MyExamTest----codemirror 三、 笙默考试管理系统-MyExamTest----codemirror 四、 笙默考试管理系统-MyExamTest---…...

git在本地创建dev分支并和远程的dev分支关联起来

文章目录 git在本地创建dev分支并和远程的dev分支关联起来1. 使用git命令2. 使用idea2.1 先删除上面建的本地分支dev2.2 通过idea建dev分支并和远程dev分支关联 3. 查看本地分支和远程分支的关系 git在本地创建dev分支并和远程的dev分支关联起来 1. 使用git命令 git checkout…...

【C++】深入了解构造函数之初始化列表

目录 一、再谈构造函数 1、引入 1&#xff09;构造函数体赋值 2&#xff09;不同成员变量赋值 2、初始化列表 一、再谈构造函数 1、引入 1&#xff09;构造函数体赋值 在创建对象时&#xff0c;编译器通过调用构造函数&#xff0c;给对象中各个成员变量一个合适的初始值…...

差分--差分数组快速计算L到R值相加后的数组

目录 差分&#xff1a;思路代码&#xff1a; 原题链接 差分&#xff1a; 输入一个长度为 n 的整数序列。 接下来输入 m 个操作&#xff0c;每个操作包含三个整数 l,r,c &#xff0c;表示将序列中 [l,r] 之间的每个数加上 c 。 请你输出进行完所有操作后的序列。 输入格式 第…...

《NLP入门到精通》栏目导读(01/2)

一、说明 栏目《NLP入门到精通》本着从简到难得台阶式学习过度。将自然语言处理得知识贯穿过来。本栏目得前导栏目是《深度学习》、《pytorch实践》,因此,读者需要一定得深度学习基础,才能过度到此栏目内容。 二、博客建设理念 本博客基地,将建成人工智能领域的参考资料库;…...

three.js实现电子围栏效果(纹理贴图)

three.js实现电子围栏效果&#xff08;纹理贴图&#xff09; 实现步骤 围栏的坐标坐标转换为几何体顶点&#xff0c;uv顶点坐标加载贴图&#xff0c;移动 图例 代码 <template><div class"app"><div ref"canvesRef" class"canvas-…...

DHSP和DNS

一、服务程序 1.1DHCP定义 DHCP&#xff08;动态主机配置协议&#xff09;是一个局域网的网络协议。指的是由服务器控制一段IP地址范围&#xff0c;客户机登录服务器时就可以自动获得服务器分配的IP地址和子网掩码。默认情况下&#xff0c;DHCP作为Windows Server的一个服务组…...

Python冒号的解释

1. “没什么首次没有为第二个&#xff0c;跳了三个”。它得到的切片序列的每一个第三个项目。 扩展片是你想要的。新在Python 2.3 2. Python的序列切片地址可以写成[开始&#xff1a;结束&#xff1a;一步]和任何启动&#xff0c;停止或结束可以被丢弃。a[::3]是每第三个序列。…...

uniapp微信小程序投票系统实战 (SpringBoot2+vue3.2+element plus ) -后端鉴权拦截器实现

锋哥原创的uniapp微信小程序投票系统实战&#xff1a; uniapp微信小程序投票系统实战课程 (SpringBoot2vue3.2element plus ) ( 火爆连载更新中... )_哔哩哔哩_bilibiliuniapp微信小程序投票系统实战课程 (SpringBoot2vue3.2element plus ) ( 火爆连载更新中... )共计21条视频…...

固乔快递查询助手:批量、快速、全面的快递信息查询软件

在快递行业飞速发展的今天&#xff0c;如何高效、准确地掌握快递信息成为了很多人的需求。而固乔快递查询助手正是解决这一难题的利器。 固乔快递查询助手是一款专注于快递信息查询的软件&#xff0c;支持多家主流快递公司查询。用户只需输入单号&#xff0c;即可快速查询到实时…...

云原生核心技术 (7/12): K8s 核心概念白话解读(上):Pod 和 Deployment 究竟是什么?

大家好&#xff0c;欢迎来到《云原生核心技术》系列的第七篇&#xff01; 在上一篇&#xff0c;我们成功地使用 Minikube 或 kind 在自己的电脑上搭建起了一个迷你但功能完备的 Kubernetes 集群。现在&#xff0c;我们就像一个拥有了一块崭新数字土地的农场主&#xff0c;是时…...

R语言AI模型部署方案:精准离线运行详解

R语言AI模型部署方案:精准离线运行详解 一、项目概述 本文将构建一个完整的R语言AI部署解决方案,实现鸢尾花分类模型的训练、保存、离线部署和预测功能。核心特点: 100%离线运行能力自包含环境依赖生产级错误处理跨平台兼容性模型版本管理# 文件结构说明 Iris_AI_Deployme…...

在鸿蒙HarmonyOS 5中实现抖音风格的点赞功能

下面我将详细介绍如何使用HarmonyOS SDK在HarmonyOS 5中实现类似抖音的点赞功能&#xff0c;包括动画效果、数据同步和交互优化。 1. 基础点赞功能实现 1.1 创建数据模型 // VideoModel.ets export class VideoModel {id: string "";title: string ""…...

Linux云原生安全:零信任架构与机密计算

Linux云原生安全&#xff1a;零信任架构与机密计算 构建坚不可摧的云原生防御体系 引言&#xff1a;云原生安全的范式革命 随着云原生技术的普及&#xff0c;安全边界正在从传统的网络边界向工作负载内部转移。Gartner预测&#xff0c;到2025年&#xff0c;零信任架构将成为超…...

【JavaSE】绘图与事件入门学习笔记

-Java绘图坐标体系 坐标体系-介绍 坐标原点位于左上角&#xff0c;以像素为单位。 在Java坐标系中,第一个是x坐标,表示当前位置为水平方向&#xff0c;距离坐标原点x个像素;第二个是y坐标&#xff0c;表示当前位置为垂直方向&#xff0c;距离坐标原点y个像素。 坐标体系-像素 …...

Yolov8 目标检测蒸馏学习记录

yolov8系列模型蒸馏基本流程&#xff0c;代码下载&#xff1a;这里本人提交了一个demo:djdll/Yolov8_Distillation: Yolov8轻量化_蒸馏代码实现 在轻量化模型设计中&#xff0c;**知识蒸馏&#xff08;Knowledge Distillation&#xff09;**被广泛应用&#xff0c;作为提升模型…...

LINUX 69 FTP 客服管理系统 man 5 /etc/vsftpd/vsftpd.conf

FTP 客服管理系统 实现kefu123登录&#xff0c;不允许匿名访问&#xff0c;kefu只能访问/data/kefu目录&#xff0c;不能查看其他目录 创建账号密码 useradd kefu echo 123|passwd -stdin kefu [rootcode caozx26420]# echo 123|passwd --stdin kefu 更改用户 kefu 的密码…...

音视频——I2S 协议详解

I2S 协议详解 I2S (Inter-IC Sound) 协议是一种串行总线协议&#xff0c;专门用于在数字音频设备之间传输数字音频数据。它由飞利浦&#xff08;Philips&#xff09;公司开发&#xff0c;以其简单、高效和广泛的兼容性而闻名。 1. 信号线 I2S 协议通常使用三根或四根信号线&a…...

Spring Security 认证流程——补充

一、认证流程概述 Spring Security 的认证流程基于 过滤器链&#xff08;Filter Chain&#xff09;&#xff0c;核心组件包括 UsernamePasswordAuthenticationFilter、AuthenticationManager、UserDetailsService 等。整个流程可分为以下步骤&#xff1a; 用户提交登录请求拦…...

若依登录用户名和密码加密

/*** 获取公钥&#xff1a;前端用来密码加密* return*/GetMapping("/getPublicKey")public RSAUtil.RSAKeyPair getPublicKey() {return RSAUtil.rsaKeyPair();}新建RSAUti.Java package com.ruoyi.common.utils;import org.apache.commons.codec.binary.Base64; im…...