硬盘序列号示例_序列化代理模式示例
硬盤序列號示例
有些書極大地改變了你的生活。 其中一本書是Joshua Bloch撰寫的“ Effective Java” 。 在下面您可能會發現一些小的實驗,該實驗的靈感來自于本書的第11章“串行化”。
假設我們有一個為繼承而設計的類,它本身不是可序列化的 ,并且沒有無參數的構造函數,如以下示例所示:
現在,當我們擴展此類時,例如通過以下方式:
public class ConvenientPoint extends CumbersomePoint implements Serializable {public ConvenientPoint(double x, double y, String name) {super(x, y, name);}... }并嘗試序列化然后反序列化任何ConvenientPoint實例,我們將很快遇到漂亮的InvalidClassException ,抱怨沒有有效的構造函數。 在您應用稱為序列化代理模式的技術之前,情況看起來有點絕望。
首先,將內部類添加到ConvenientPoint類中:
private static class SerializationProxy implements Serializable {private String name;private double x;private double y;public SerializationProxy(ConvenientPoint point) {this.name = point.getName();this.x = point.getX();this.y = point.getY();}private Object readResolve() {return new ConvenientPoint(x, y, name);}}SerializationProxy類將表示封閉類實例的邏輯狀態。 我們還必須在ConvenientPoint類中添加以下方法:
private Object writeReplace() {return new SerializationProxy(this);}現在,當ConvenientPoint實例將被序列化時,由于writeReplace方法,它將提名其替換對象– 序列化 代理實例將被序列化而不是ConvenientPoint 。
另一方面,當序列化代理將被反序列化時, readResolve方法的使用將提名其替代品,即ConvenientPoint實例。
如您所見,無論缺少不可序列化的父類的無參數構造函數,我們都使ConvenientPoint可序列化。
在本文結尾處,還有一句話–如果要防止破壞由構造函數強制執行的類不變式,可以使用序列化代理模式 (在我們的示例中為ConvenientPoint)在類中添加以下方法:
private void readObject(ObjectInputStream stream) throws InvalidObjectException {throw new InvalidObjectException("Use Serialization Proxy instead.");}這將防止對封裝類進行反序列化。
翻譯自: https://www.javacodegeeks.com/2014/06/serialization-proxy-pattern-example.html
硬盤序列號示例
總結
以上是生活随笔為你收集整理的硬盘序列号示例_序列化代理模式示例的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 至强cpu装机方案?
- 下一篇: 情侣头像真人有电脑系统(qq头像真人情侣