serializable作用

本文详细介绍了Java中序列化的概念及其实现方式。序列化能够帮助开发者在网络上传输对象,并且支持RMI远程方法调用和JavaBeans状态信息的保存与恢复。

没有implements Serializable,你就不能通过rmi(包括ejb)提供远程调用。 serialization 允许你将实现了Serializable接口的对象转换为字节序列,这些字节序列可以被完全存储以备以后重新生成原来的对象。 serialization不但可以在本机做,而且可以经由网络操作(就是猫小说的RMI)。这个好处是很大的----因为它自动屏蔽了操作系统的差异,字节顺序等。比如,在Window平台生成一个对象并序列化之,然后通过网络传到一台Unix机器上,然后可以在这台Unix机器上正确地重构这个对象。 Object serialization主要用来支持2种主要的特性: 1.Java的RMI(remote method invocation).RMI允许象在本机上一样操作远程机器上的对象。当发送消息给远程对象时,就需要用到serializaiton机制来发送参数和接收返回直。 2.Java的JavaBeans. Bean的状态信息通常是在设计时配置的。Bean的状态信息必须被存起来,以便当程序运行时能恢复这些状态信息。这也需要serializaiton机制。 下面是关于serializable的一个例子,如果MyClass不实现serializable,程序将抛出异常

 

总之如果在网络的环境下做类传输,应该还是应该implements Serializable.

### implements Serializable作用 在 Java 中,`Serializable` 是一个标记接口(即没有方法的接口),用于标识某个类的对象可以被序列化。序列化是指将对象的状态转换为字节序列的过程,以便于存储或传输;而反序列化则是将字节序列重新转换为对象的过程。 实现 `Serializable` 接口的主要作用是允许对象通过 `ObjectOutputStream` 和 `ObjectInputStream` 进行序列化和反序列化操作。如果一个类没有实现该接口,尝试对其进行序列化时会抛出 `NotSerializableException` 异常 [^2]。 此外,`Serializable` 接口还支持跨语言通信中的数据交换需求。例如,在 Java 与其他语言(如 Python 或 JavaScript)之间进行交互时,可能需要将对象转换为通用格式(如 JSON 或 XML)。此时,序列化过程可以帮助实现这种转换 [^3]。 ### 使用场景 1. **持久化存储**:当需要将对象的状态保存到文件系统或数据库中时,可以通过序列化来实现。这使得对象可以在程序重启后仍然保持其状态 。 2. **网络传输**:在网络编程中,序列化可用于将对象发送到远程主机或者接收来自远程主机的对象。这对于分布式应用非常有用 [^3]。 3. **跨平台通信**:在不同平台之间交换数据时,序列化可以确保数据的一致性。例如,在 Web 服务中,客户端和服务端可能使用不同的技术栈,但都可以处理标准的序列化格式 。 4. **缓存机制**:某些情况下,为了提高性能,可能会将频繁使用的对象序列化后存储在内存或磁盘上,从而避免重复创建对象的成本 [^5]。 5. **RMI (Remote Method Invocation)**:Java RMI 使用序列化来传递参数和返回值。因此,所有涉及 RMI 调用的对象都必须实现 `Serializable` 接口 [^4]。 ### 示例代码 以下是一个简单的例子,展示如何实现 `Serializable` 接口并进行序列化与反序列化操作: ```java 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 { // 序列化 ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("user.ser")); oos.writeObject(new User("张三", 25)); oos.close(); // 反序列化 ObjectInputStream ois = new ObjectInputStream(new FileInputStream("user.ser")); User user = (User) ois.readObject(); ois.close(); System.out.println(user); } } ``` 在这个示例中,`User` 类实现了 `Serializable` 接口,并且包含了 `serialVersionUID` 字段以保证版本兼容性。然后通过 `ObjectOutputStream` 和 `ObjectInputStream` 分别进行了序列化和反序列化操作 [^2]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值