技术文摘
Java Socket通信中序列化与反序列化代码详解
Java Socket通信中序列化与反序列化代码详解
在Java的Socket通信中,序列化与反序列化起着至关重要的作用。它们使得对象能够在网络中进行传输和接收,实现了数据的有效交互。
我们来了解一下序列化。序列化是将对象转换为字节流的过程,以便在网络上传输或保存到文件中。在Java中,要实现序列化,对象所属的类必须实现java.io.Serializable接口。这个接口是一个标记接口,没有任何方法需要实现,它只是告诉Java虚拟机该类的对象可以被序列化。
下面是一个简单的示例代码,定义一个可序列化的类:
import java.io.Serializable;
class Person implements Serializable {
private String name;
private int age;
public Person(String name, int age) {
this.name = name;
this.age = age;
}
// 省略getter和setter方法
}
在发送端,我们需要将Person对象序列化并通过Socket发送出去:
import java.io.ObjectOutputStream;
import java.net.Socket;
public class Sender {
public static void main(String[] args) throws Exception {
Socket socket = new Socket("localhost", 8888);
Person person = new Person("Alice", 25);
ObjectOutputStream oos = new ObjectOutputStream(socket.getOutputStream());
oos.writeObject(person);
oos.close();
socket.close();
}
}
接下来是反序列化。反序列化是将字节流转换回对象的过程。在接收端,我们从Socket接收字节流并进行反序列化:
import java.io.ObjectInputStream;
import java.net.ServerSocket;
import java.net.Socket;
public class Receiver {
public static void main(String[] args) throws Exception {
ServerSocket serverSocket = new ServerSocket(8888);
Socket socket = serverSocket.accept();
ObjectInputStream ois = new ObjectInputStream(socket.getInputStream());
Person person = (Person) ois.readObject();
System.out.println("Received: " + person.getName() + ", " + person.getAge());
ois.close();
socket.close();
serverSocket.close();
}
}
通过上述代码,我们实现了在Java Socket通信中的序列化与反序列化,使得对象能够在网络中顺利传输和接收,为分布式应用开发提供了有力支持。
TAGS: 序列化 代码详解 反序列化 Java Socket通信
- 谷歌 CEO 为何称员工效率低?
- 解析 Kafka 副本 Leader 选举原理
- 魔改 xxL-Job ,告别手动配置任务
- 图片加载相关知识,你得学学
- 11 个超酷的 Chrome Devtools 技巧
- 前端利用 husky 借助 eslint 检测提交代码
- Kafka 性能下降迅速原因,RocketMQ 无此状况
- Webpack5 那些与众不同的改变之我见
- 12 个开源跨平台桌面项目推荐
- Java 服务异常排查与定位全景图
- 一行代码实现 Python 程序的图形界面转换
- 简单易用的 Python 汉字拼音转换工具
- 建筑学小哥自称编程菜鸟 竟攒出彩色 Text-to-3D 的 AI 作画三维版
- 面试题:一个 Consumer 订阅两 Topic,一 Topic 消息堆积会影响另一 Topic 消费吗?
- K8s 命令:程序解 Bug 常用与使用窍门