(每日持续更新)jdk api之ObjectInputStream基础、应用、实战

2024-02-10 04:52

本文主要是介绍(每日持续更新)jdk api之ObjectInputStream基础、应用、实战,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

博主18年的互联网软件开发经验,从一名程序员小白逐步成为了一名架构师,我想通过平台将经验分享给大家,因此博主每天会在各个大牛网站点赞量超高的博客等寻找该技术栈的资料结合自己的经验,晚上进行用心精简、整理、总结、定稿,每天都会整理到12点,为了就是能让大家能够真正了解该技术栈的真正原理,最终从程序员成为一名真正的架构师,写的不一定是全站做好的,但是是全站最用心的~。

以后我会推出一些列的文章,每天都会更新,每天进步一点点,发布顺序【java的api基础、应用、实战】->【java开源技术栈及源码分析】->【java开源技术栈整合】->【java低代码开发平台的建设】

关注【架构师成长之道】 输入“架构师视频课程”,即可免费获得全套架构师全套课程

一、java.io

1.44 ObjectInputStream

ObjectInputStream类是用于从输入流中读取Java对象的类,它可以将对象从字节流反序列化为Java对象。以下是关于ObjectInputStream类的基本介绍:

ObjectInputStream 介绍:
所有字段:
  • protected ObjectInputStream$GetField fields 用于读取序列化对象的字段值的GetField对象。

构造方法:
  • protected ObjectInputStream() throws IOException, SecurityException:创建一个新的ObjectInputStream,它使用默认的类加载器和默认的安全管理器。

  • ObjectInputStream(InputStream in) throws IOException:使用指定的输入流创建一个新的ObjectInputStream

方法摘要:
  • void defaultReadObject() 从流中读取默认的对象字段值,以恢复对象的状态。

  • GetField readFields() 读取序列化对象的字段值,返回一个GetField对象,可以用于访问字段的值。

  • int read() 从输入流中读取一个字节的数据。

  • Object readObject() 从输入流中读取对象。

  • int read(byte[] buf, int off, int len) 从输入流中读取字节数组的一部分数据。

  • Object readUnshared() 从输入流中读取一个未共享的对象。

  • void registerValidation(ObjectInputValidation obj, int prio) 注册一个对象验证回调。

简单使用例子:
javaCopy code
import java.io.*;
​
public class ObjectInputStreamExample {
​public static void main(String[] args) {String fileName = "data.ser";saveDataToFile(fileName);loadDataFromFile(fileName);}
​private static void saveDataToFile(String fileName) {try (ObjectOutputStream outputStream = new ObjectOutputStream(new FileOutputStream(fileName))) {// 将对象保存到文件MyObject obj = new MyObject("Hello, ObjectInputStream!");outputStream.writeObject(obj);System.out.println("Object saved to file successfully.");} catch (IOException e) {e.printStackTrace();}}
​private static void loadDataFromFile(String fileName) {try (ObjectInputStream inputStream = new ObjectInputStream(new FileInputStream(fileName))) {// 从文件加载对象MyObject obj = (MyObject) inputStream.readObject();System.out.println("Loaded object from file: " + obj.getData());} catch (IOException | ClassNotFoundException e) {e.printStackTrace();}}
​static class MyObject implements Serializable {private static final long serialVersionUID = 1L;private String data;
​public MyObject(String data) {this.data = data;}
​public String getData() {return data;}}
}

在这个简单的例子中,我们创建了一个MyObject类,它实现了Serializable接口,表示可以序列化。我们将一个MyObject对象保存到文件中,并使用ObjectInputStream从文件中加载对象。加载的对象可以强制转换为MyObject类型,并访问其数据。

应用场景

以下是一些使用 ObjectInputStream 的常见应用场景及相应的代码实现:

应用场景 1: 从文件中读取对象并进行处理
javaCopy code
import java.io.*;
​
public class ReadObjectsFromFile {public static void main(String[] args) {String fileName = "data.ser";try (ObjectInputStream inputStream = new ObjectInputStream(new FileInputStream(fileName))) {Object obj = inputStream.readObject();// 处理从文件中读取的对象System.out.println("Object read from file: " + obj);} catch (IOException | ClassNotFoundException e) {e.printStackTrace();}}
}
应用场景 2: 从网络流中读取对象并进行处理
javaCopy code
import java.io.*;
import java.net.*;
​
public class ReadObjectsFromNetwork {public static void main(String[] args) {try {Socket socket = new Socket("localhost", 8080);ObjectInputStream inputStream = new ObjectInputStream(socket.getInputStream());Object obj = inputStream.readObject();// 处理从网络流中读取的对象System.out.println("Object read from network: " + obj);inputStream.close();socket.close();} catch (IOException | ClassNotFoundException e) {e.printStackTrace();}}
}
应用场景 3: 从字节数组中读取对象并进行处理
javaCopy code
import java.io.*;
​
public class ReadObjectsFromByteArray {public static void main(String[] args) {byte[] data = {/* Byte array with serialized object data */};try (ByteArrayInputStream byteInput = new ByteArrayInputStream(data);ObjectInputStream inputStream = new ObjectInputStream(byteInput)) {Object obj = inputStream.readObject();// 处理从字节数组中读取的对象System.out.println("Object read from byte array: " + obj);} catch (IOException | ClassNotFoundException e) {e.printStackTrace();}}
}
应用场景 4: 读取多个对象直到文件末尾
javaCopy code
import java.io.*;
​
public class ReadMultipleObjects {public static void main(String[] args) {String fileName = "data.ser";try (ObjectInputStream inputStream = new ObjectInputStream(new FileInputStream(fileName))) {while (true) {try {Object obj = inputStream.readObject();// 处理每个读取的对象System.out.println("Object read from file: " + obj);} catch (EOFException e) {// 文件末尾,退出循环break;}}} catch (IOException | ClassNotFoundException e) {e.printStackTrace();}}
}

这些例子涵盖了从文件、网络、字节数组中读取对象以及处理多个对象的场景。通过 ObjectInputStream 可以方便地实现从不同来源读取对象并进行相应处理。

实战例子

以下是一个简单的项目实战例子,演示了如何使用 ObjectInputStream 读取对象并进行处理:

javaCopy code
import java.io.*;
​
public class ObjectInputStreamExample {
​static class Person implements Serializable {private static final long serialVersionUID = 1L;private String name;private int age;
​public Person(String name, int age) {this.name = name;this.age = age;}
​@Overridepublic String toString() {return "Person{" +"name='" + name + '\'' +", age=" + age +'}';}}
​public static void main(String[] args) {String fileName = "person.ser";
​// 写入对象到文件writeObjectToFile(fileName);
​// 从文件读取对象并处理readObjectFromFile(fileName);}
​private static void writeObjectToFile(String fileName) {try (ObjectOutputStream outputStream = new ObjectOutputStream(new FileOutputStream(fileName))) {Person person = new Person("Alice", 30);outputStream.writeObject(person);System.out.println("Object written to file successfully.");} catch (IOException e) {e.printStackTrace();}}
​private static void readObjectFromFile(String fileName) {try (ObjectInputStream inputStream = new ObjectInputStream(new FileInputStream(fileName))) {Object obj = inputStream.readObject();if (obj instanceof Person) {Person person = (Person) obj;System.out.println("Object read from file: " + person);}} catch (IOException | ClassNotFoundException e) {e.printStackTrace();}}
}

在这个示例中,我们定义了一个 Person 类,实现了 Serializable 接口,表示可以序列化。然后我们将一个 Person 对象写入到文件中,并使用 ObjectInputStream 从文件中读取对象。加载的对象可以转换为 Person 类型,并输出到控制台。

这篇关于(每日持续更新)jdk api之ObjectInputStream基础、应用、实战的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/696168

相关文章

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

Deepseek R1模型本地化部署+API接口调用详细教程(释放AI生产力)

《DeepseekR1模型本地化部署+API接口调用详细教程(释放AI生产力)》本文介绍了本地部署DeepSeekR1模型和通过API调用将其集成到VSCode中的过程,作者详细步骤展示了如何下载和... 目录前言一、deepseek R1模型与chatGPT o1系列模型对比二、本地部署步骤1.安装oll

浅析如何使用Swagger生成带权限控制的API文档

《浅析如何使用Swagger生成带权限控制的API文档》当涉及到权限控制时,如何生成既安全又详细的API文档就成了一个关键问题,所以这篇文章小编就来和大家好好聊聊如何用Swagger来生成带有... 目录准备工作配置 Swagger权限控制给 API 加上权限注解查看文档注意事项在咱们的开发工作里,API

一分钟带你上手Python调用DeepSeek的API

《一分钟带你上手Python调用DeepSeek的API》最近DeepSeek非常火,作为一枚对前言技术非常关注的程序员来说,自然都想对接DeepSeek的API来体验一把,下面小编就来为大家介绍一下... 目录前言免费体验API-Key申请首次调用API基本概念最小单元推理模型智能体自定义界面总结前言最

在Java中使用ModelMapper简化Shapefile属性转JavaBean实战过程

《在Java中使用ModelMapper简化Shapefile属性转JavaBean实战过程》本文介绍了在Java中使用ModelMapper库简化Shapefile属性转JavaBean的过程,对比... 目录前言一、原始的处理办法1、使用Set方法来转换2、使用构造方法转换二、基于ModelMapper

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

Java实战之自助进行多张图片合成拼接

《Java实战之自助进行多张图片合成拼接》在当今数字化时代,图像处理技术在各个领域都发挥着至关重要的作用,本文为大家详细介绍了如何使用Java实现多张图片合成拼接,需要的可以了解下... 目录前言一、图片合成需求描述二、图片合成设计与实现1、编程语言2、基础数据准备3、图片合成流程4、图片合成实现三、总结前

C#使用DeepSeek API实现自然语言处理,文本分类和情感分析

《C#使用DeepSeekAPI实现自然语言处理,文本分类和情感分析》在C#中使用DeepSeekAPI可以实现多种功能,例如自然语言处理、文本分类、情感分析等,本文主要为大家介绍了具体实现步骤,... 目录准备工作文本生成文本分类问答系统代码生成翻译功能文本摘要文本校对图像描述生成总结在C#中使用Deep