异常类的可序列化

让你的异常类的序列化!

老实说,我生病和调试怪异SerializationExceptions的,因为一个写得不好的异常类的一个实例跨越AppDomain边界累。 我能理解它,如果它是一个例外真的是不可能的序列化的类,但现实却是,这主要是由开发的部分lazyness引起的。

提示#1:异常是不是由默认的序列化。 如果您创建一个自定义异常类,它是 responsability,以确保它是可序列化的。

提示#2:标记[Serializable的]的异常类是不够的。 System.Exception的实现ISerializable的,所以它迫使你这样做。 

在这里,你应该写一个异常类时,请记住:

  1. [Serializable]属性标记的异常的类型。
  2. 添加一个空的保护序列化的构造简单代表的基类:

保护MyException(SerializationInfo中信息的StreamingContext ctxt):基地(详细信息,ctxt)

对于大多数的异常类,这将是不够的,因为大多数不实际添加新的属性和单纯依靠消息。

但是,如果您的自定义异常类自定义属性,那么它必须重写ISerializable.GetObjectData()(不要忘了调用基地之一),你必须解开这些属性在您的序列化构造。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
内部类的序列化过程和普通类是一样的。但是,需要注意的是,如果内部类是非静态的,则需要序列化其外部类的引用,以便在反序列化时能够正确地重建内部类实例。同时,如果内部类实现了 Serializable 接口,则需要确保其外部类也实现了 Serializable 接口,否则在序列化时会抛出 NotSerializableException 异常。 以下是一个示例代码: ```java import java.io.*; class Outer implements Serializable { private static final long serialVersionUID = 1L; private int outerValue; public Outer(int outerValue) { this.outerValue = outerValue; } public int getOuterValue() { return outerValue; } public void setOuterValue(int outerValue) { this.outerValue = outerValue; } class Inner implements Serializable { private static final long serialVersionUID = 1L; private int innerValue; public Inner(int innerValue) { this.innerValue = innerValue; } public int getInnerValue() { return innerValue; } public void setInnerValue(int innerValue) { this.innerValue = innerValue; } } } public class SerializationExample { public static void main(String[] args) throws Exception { Outer outer = new Outer(10); Outer.Inner inner = outer.new Inner(20); // 序列化 FileOutputStream fos = new FileOutputStream("data.ser"); ObjectOutputStream oos = new ObjectOutputStream(fos); oos.writeObject(outer); oos.close(); // 反序列化 FileInputStream fis = new FileInputStream("data.ser"); ObjectInputStream ois = new ObjectInputStream(fis); Outer outer2 = (Outer) ois.readObject(); ois.close(); // 验证序列化结果 System.out.println("Outer value: " + outer2.getOuterValue()); System.out.println("Inner value: " + outer2.new Inner(0).getInnerValue()); } } ``` 在上面的示例中,我们定义了一个包含内部类的外部类 Outer,并进行了序列化和反序列化。注意,在序列化和反序列化时,我们都需要将外部类和内部类同时序列化和反序列化。最终输出的结果如下: ``` Outer value: 10 Inner value: 20 ``` 这表明内部类的序列化和反序列化过程都是成功的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值