spring持久类po或者javabean为什么常常实现序列化?

       无论用hibernate或者mybatis结合spring做开发还是其他,系统里持久类往往要实现序列化, implements Serializable。我还是比较好奇,为什么要这样做呢?一直只知道个大概,学习hibernate和mybatis时,一些书中有几个字的介绍,有的书中举得例子或者和spring整合时举得例子也没实现序列化,有时可能在你项目上,如果不是实现serializable接口,可能系统也会正常不会出现错误。

       终于有这个时间自己查查这个原因了,翻翻书,看看网页,针对这个问题资料还是比较少的,不过本人也了解到了一些,对po实现序列化有了更深的了解,为什么要实现序列化原因总结如下:

1、Hibernate使用组件作为复合主键时,该组件类必须满足一个条件就是:实现java.io.serializable接口。

2、MyBatis中配置缓存时,持久层需实现序列化。缓存元素<cache>有个readOnly属性,readOnly属性可以被设置为 true 或 false。只读缓存将对所有调用者返回同一个实例。因此都不能被修改,这可以极大的提高性能。可写的缓存将通过序列化来返回一个缓存对象的拷贝。这会比较慢,但是比较安全。所以默认值是 false。

3、持久存储,将对象的状态保存在存储媒体中以便可以在以后重新创建出完全相同的副本。

4、按值封送,尤其是在分布式系统中。如果对象标记为 Serializable,则该对象将被自动序列化

### JavaBean 实现 `Serializable` 接口的原因和作用 JavaBean 实现 `Serializable` 接口的主要目的是为了支持对象的序列化与反序列化操作。序列化是指将对象的状态转换为可以存储传输的形式(例如字节序列),而反序列化则是将存储传输的数据重新构建为对象的过程。通过实现 `Serializable` 接口,JavaBean 可以实现以下功能: #### 1. 持久化存储对象状态 JavaBean 的状态信息可以通过序列化保存到文件数据库中,以便在程序重新启动时恢复对象的状态。这对于需要长期保存对象数据的应用场景非常有用。例如,一个用户界面构造工具可以保存 JavaBean 的配置信息,并在下次加载时恢复其状态 [^1]。 #### 2. 支持远程方法调用 (RMI) Java 的远程方法调用(RMI)机制允许在不同的 Java 虚拟机之间调用对象的方法。在 RMI 调用过程中,参数和返回值需要通过网络传输,而对象的序列化实现这一功能的关键。只有实现了 `Serializable` 接口的对象才能被序列化并通过网络传输 [^3]。 #### 3. 网络传输 序列化使得 JavaBean 可以在网络上传输。例如,在分布式系统中,JavaBean 可以被序列化为字节流,然后发送到其他节点进行处理。这种机制简化了跨网络通信的开发。 #### 4. 对象深拷贝 通过序列化和反序列化操作,可以实现对象的深拷贝。具体做法是将对象序列化到内存中,然后立即反序列化,从而创建一个与原对象完全独立的新对象。这种方式特别适用于需要复制复杂对象结构的场景。 #### 5. 选择性序列化 在某些情况下,可能不希望序列化 JavaBean 的所有字段。例如,一些临时性变量敏感信息可能不需要保存。可以通过使用 `transient` 关键字标记这些字段,从而在序列化过程中忽略它们。反序列化时,这些字段会被初始化为其默认值(如基本类型为 `0` `false`,对象为 `null`) [^2]。 #### 示例代码 以下是一个简单的 JavaBean 示例,展示了如何实现 `Serializable` 接口并使用序列化功能: ```java import java.io.*; public class User implements Serializable { private static final long serialVersionUID = 1L; private String name; private transient 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("Alice", 30); // 序列化对象 try (ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("user.ser"))) { oos.writeObject(user); } // 反序列化对象 try (ObjectInputStream ois = new ObjectInputStream(new FileInputStream("user.ser"))) { User deserializedUser = (User) ois.readObject(); System.out.println(deserializedUser); } } } ``` 在上述代码中,`User` 类实现了 `Serializable` 接口,并且 `age` 字段被标记为 `transient`,因此在序列化过程中不会被保存。 ---
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值