0

XMLEncoder 构造器初始化状态优化非常棒,除非您需要它来对构造器设置的某些状态之后的实际状态集进行编码。这似乎是一个错误(或缺少功能:-))。

import java.beans.Encoder;
import java.beans.Expression;
import java.beans.PersistenceDelegate;
import java.beans.XMLEncoder;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;

public class XMLEncoderBug {
    private File file;

    public XMLEncoderBug() {
        //this.setFile(".");
    }

    public File getFile() {
        return this.file;
    }

    public void setFile(String fileName) {
        this.setFile(new File(fileName));
    }

    public void setFile(File file) {
        this.file = file;
    }

    public static void main(String[] args) throws IOException {
        XMLEncoderBug bean = new XMLEncoderBug();
        bean.setFile(new File("./test/test/test"));

        FileOutputStream fout = new FileOutputStream("TestBean.xml");
        XMLEncoder enc = new XMLEncoder(fout);

        enc.setPersistenceDelegate(File.class, new PersistenceDelegate() {
            protected Expression instantiate(Object oldInstance, Encoder out) {
                System.out.printf("FilePersistenceDelegate.instantiate(oldInstance=%s, out)\n", oldInstance.getClass().getName());
                File file = (File)oldInstance;
                String fileName = file.getAbsolutePath();

                return new Expression(file, file.getClass(), "new", new Object[]{ fileName });
            }
        });

        enc.writeObject(bean);
        enc.flush();
        fout.flush();
        enc.close();
        fout.close();
    }
}

所以,按原样运行代码。一切都按预期编码。然后,取消注释构造函数中的行并再次运行它。请注意 bean 的实际状态如何未正确持久化。

现在,我了解了 XMLEncoder 的优化,它不会对由无参数构造函数设置的任何状态进行编码,因为在解码期间不需要调用构造函数并将状态初始化为构造函数所做的任何事情。

但是,当状态由构造函数以某种方式初始化随后更改时,实例的持久状态肯定没有被正确编码。

我错过了什么吗?

顺便说一句:Java 1.8。

4

0 回答 0