java.io.ObjectInputStream.resolveObject(Object obj) 方法允许ObjectInputStream的受信任子类反序列化过程中一个对象替代另一个。替换对象被禁用,直到enableResolveObject被调用。该enableResolveObject方法检查流要求解决的对象是可以信任的。每个引用序列化的对象传递给resolveObject。为了确保对象的私有状态不是无意间露出只有受信任的流使用resolveObject。
这种方法被称为一个对象已被读取后,但在此之前它是从readObject返回。默认resolveObject方法只返回相同的对象。
当一个子类取代对象时,必须确保在替代对象与参考将被存储的每个字段兼容。对象,其类型不是字段或数组元素中止序列化的通过引发异常,对象不会被保存的类型的子类。
声明
以下是java.io.ObjectInputStream.resolveObject()方法的声明
protected Object resolveObject(Object obj)
参数
-
obj -- 被取代的对象
返回值
此方法返回取代的对象
异常
-
IOException -- 任何通常的输入/输出异常。
例子
下面的示例演示java.io.ObjectInputStream.resolveObject()方法的用法。
package com.yiibai; import java.io.*; public class ObjectInputStreamDemo extends ObjectInputStream { public ObjectInputStreamDemo(InputStream in) throws IOException { super(in); } public static void main(String[] args) { String s = "Hello World"; try { // create a new file with an ObjectOutputStream FileOutputStream out = new FileOutputStream("test.txt"); ObjectOutputStream oout = new ObjectOutputStream(out); // write something in the file oout.writeUTF(s); oout.flush(); // create an ObjectInputStream for the file we created before ObjectInputStreamDemo ois = new ObjectInputStreamDemo(new FileInputStream("test.txt")); // enable object resolving ois.enableResolveObject(true); // get the class for string and print the name System.out.println("" + ois.resolveObject(ois.readUTF())); } catch (Exception ex) { ex.printStackTrace(); } } }
让我们编译和运行上面的程序,这将产生以下结果:
Hello World