Entity实体类为什么要实现Serializable接口才能被序列化

探讨了实体类实现Serializable接口的原因,以及序列化的两种主要方式:实现Serializable和Externalizable接口。分析了它们之间的区别,包括效率、灵活性及如何处理transient关键字。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

疯狂面试题

Entity实体类为什么要实现Serializable接口才能被序列化

ObjectOutputStream 来持久化对象, 对于此处抛出的异常,查看该类中实现如下:

private void writeObject0(Object obj, boolean unshared) throws IOException {
    // ...
            // remaining cases
            if (obj instanceof String) {
                writeString((String) obj, unshared);
            } else if (cl.isArray()) {
                writeArray(obj, desc, unshared);
            } else if (obj instanceof Enum) {
                writeEnum((Enum) obj, desc, unshared);
            } else if (obj instanceof Serializable) {
                writeOrdinaryObject(obj, desc, unshared);
            } else {
                if (extendedDebugInfo) {
                    throw new NotSerializableException(
                        cl.getName() + "\n" + debugInfoStack.toString());
                } else {
                    throw new NotSerializableException(cl.getName());
                }
            }
    // ...
}

序列化的两种方式

一种是实现Serializable接口

另一种是实现Exteranlizable接口。 需要重写writeExternal和readExternal方法,它的效率比Serializable高一些,并且可以决定哪些属性需要序列化(即使是transient修饰的),但是对大量对象,或者重复对象,则效率低。

从上面的这两种序列化方式,我想你已经看到了,使用Exteranlizable接口实现序列化时,我们自己指定那些属性是需要序列化的,即使是transient修饰的。实现了Externalizable接口,哪一个属性被序列化使我们手动去指定的,即使是transient关键字修饰也不起作用。

  • 静态变量是不会被序列化的,即使没有transient关键字修饰。
  • transient的作用就是把这个字段的生命周期仅存于调用者的内存中而不会写到磁盘里持久化
实体类序列化为字符串通常是指将对象转换为字符串格式,以便可以轻松地存储或传输。在Java中,可以使用`java.io.Serializable`接口和`ObjectOutputStream`类实现对象到字符串的序列化。以下是一个简单的示例步骤: 1. 确保你的实体类实现了`java.io.Serializable`接口。这个接口是一个标记接口,用于指示序列化机制的对象可以被序列化。 ```java import java.io.Serializable; public class EntityClass implements Serializable { // 类成员变量 private String name; private int age; // 构造函数 public EntityClass(String name, int age) { this.name = name; this.age = age; } // getter和setter方法 public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } } ``` 2. 使用`ObjectOutputStream`将对象写入`ByteArrayOutputStream`,然后将`ByteArrayOutputStream`的内容转换为字符串。 ```java import java.io.ByteArrayOutputStream; import java.io.ObjectOutputStream; import java.io.IOException; public class SerializationUtil { public static String serializeObjectToBase64(Object obj) throws IOException { try (ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); ObjectOutputStream objectOutputStream = new ObjectOutputStream(byteArrayOutputStream)) { objectOutputStream.writeObject(obj); return java.util.Base64.getEncoder().encodeToString(byteArrayOutputStream.toByteArray()); } } } ``` 3. 你可以调用`SerializationUtil.serializeObjectToBase64`方法来将你的实体对象转换为Base64编码的字符串。 ```java public class Main { public static void main(String[] args) { EntityClass entity = new EntityClass("张三", 30); try { String serializedString = SerializationUtil.serializeObjectToBase64(entity); System.out.println("序列化后的字符串: " + serializedString); } catch (IOException e) { e.printStackTrace(); } } } ``` 这样,你就能够将实体类对象转换为字符串形式。请注意,进行序列化时,序列化对象的所有成员也必须是可序列化的,除非它们被声明为`transient`或`static`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值