- Java.io 包类
- Java.io - 首页
- Java.io - BufferedInputStream
- Java.io - BufferedOutputStream
- Java.io - BufferedReader
- Java.io - BufferedWriter
- Java.io - ByteArrayInputStream
- Java.io - ByteArrayOutputStream
- Java.io - CharArrayReader
- Java.io - CharArrayWriter
- Java.io - Console
- Java.io - DataInputStream
- Java.io - DataOutputStream
- Java.io - File
- Java.io - FileDescriptor
- Java.io - FileInputStream
- Java.io - FileOutputStream
- Java.io - FilePermission
- Java.io - FileReader
- Java.io - FileWriter
- Java.io - FilterInputStream
- Java.io - FilterOutputStream
- Java.io - FilterReader
- Java.io - FilterWriter
- Java.io - InputStream
- Java.io - InputStreamReader
- Java.io - LineNumberInputStream
- Java.io - LineNumberReader
- Java.io - ObjectInputStream
- Java.io - ObjectInputStream.GetField
- Java.io - ObjectOutputStream
- Java.io - ObjectOutputStream.PutField
- Java.io - ObjectStreamClass
- Java.io - ObjectStreamField
- Java.io - OutputStream
- Java.io - OutputStreamWriter
- Java.io - PipedInputStream
- Java.io - PipedOutputStream
- Java.io - PipedReader
- Java.io - PipedWriter
- Java.io - PrintStream
- Java.io - PrintWriter
- Java.io - PushbackInputStream
- Java.io - PushbackReader
- Java.io - RandomAccessFile
- Java.io - Reader
- Java.io - SequenceInputStream
- Java.io - SerializablePermission
- Java.io - StreamTokenizer
- Java.io - StringBufferInputStream
- Java.io - StringReader
- Java.io - StringWriter
- Java.io - Writer
- Java.io 包附加内容
- Java.io - 接口
- Java.io - 异常
- Java.io 包有用资源
- Java.io - 讨论
Java.io.ObjectOutputStream.replaceObject() 方法
描述
java.io.ObjectOutputStream.replaceObject(Object obj) 方法允许ObjectOutputStream的可信子类在序列化期间用一个对象替换另一个对象。在调用enableReplaceObject之前,替换对象是被禁用的。enableReplaceObject方法检查请求进行替换的流是否可信。写入序列化流的每个对象的第一次出现都会传递给replaceObject。对该对象的后续引用将被replaceObject的原始调用返回的对象替换。为确保对象的私有状态不会意外泄露,只有可信流才能使用replaceObject。
ObjectOutputStream.writeObject方法采用Object类型(而不是Serializable类型)的参数,以允许处理非可序列化对象被可序列化对象替换的情况。
当子类替换对象时,它必须确保在反序列化期间必须进行补充替换,或者替换的对象与将存储引用的每个字段兼容。类型不是字段或数组元素类型的子类的对象将通过引发异常来中止序列化,并且该对象不会被存储。
此方法仅在第一次遇到每个对象时调用一次。所有后续对该对象的引用都将重定向到新对象。此方法应返回要替换的对象或原始对象。
可以返回Null作为要替换的对象,但这可能会在包含对原始对象引用的类中导致NullReferenceException,因为它们可能期望的是一个对象而不是null。
声明
以下是java.io.ObjectOutputStream.replaceObject()方法的声明。
protected Object replaceObject(Object obj)
参数
obj − 要替换的对象。
返回值
此方法返回替换指定对象的替代对象。
异常
IOException − 底层OutputStream抛出的任何异常。
示例
以下示例显示了java.io.ObjectOutputStream.replaceObject()方法的用法。
package com.tutorialspoint;
import java.io.*;
public class ObjectOutputStreamDemo extends ObjectOutputStream {
public ObjectOutputStreamDemo(OutputStream out) throws IOException {
super(out);
}
public static void main(String[] args) {
Object s2 = "Bye World!";
try {
// create a new file with an ObjectOutputStream
FileOutputStream out = new FileOutputStream("test.txt");
ObjectOutputStreamDemo oout = new ObjectOutputStreamDemo(out);
// write something in the file
oout.writeObject(s);
oout.flush();
// enable object replacing
oout.enableReplaceObject(true);
// replace object
System.out.println("" + oout.replaceObject(s2));
// close the stream
oout.close();
// create an ObjectInputStream for the file we created before
ObjectInputStream ois = new ObjectInputStream(new FileInputStream("test.txt"));
// read and print an int
System.out.println("" + (String) ois.readObject());
} catch (Exception ex) {
ex.printStackTrace();
}
}
}
让我们编译并运行上述程序,这将产生以下结果:
Bye World! Hello World!