xmlencoder如何知道属性是在对象的构造函数中设置的,从而避免输出它?
这是一个简单的示例(在Java 1.8上运行),它证明了这一点:首先定义一个带有getters和setter的简单对象以及默认构造函数:
public class Simple {
int m;
int n;
public int getM() { return m;}
public void setM(int m) {this.m = m;}
public int getN() {return n;}
public void setN(int n) {this.n = n; }
public String toString() {
return "m=" + m + ",n=" + n;
}
public Simple() {
this.m = 1;
this.n = 2;
}
}
现在,实例化对象的主要主体在其中一个属性上使用二传器,并在最终对象上调用xmlencoder。为了确保我在调用编码器之前还要打印对象的属性:
public class Main {
public static void main(String[] args) {
Simple simple = new Simple();
simple.setN(7);
System.out.println(simple.toString());
XMLEncoder encoder=null;
try{
encoder=new XMLEncoder(new BufferedOutputStream(
new FileOutputStream("simple.xml")));
}catch(FileNotFoundException fileNotFound){
System.out.println("ERROR: While Creating the File ");
}
encoder.writeObject(simple);
encoder.close();
}
}
运行程序,我得到预期的输出:m = 1,n = 7但是,当我查看生成的文件时,我会得到:
<?xml version="1.0" encoding="UTF-8"?>
<java version="1.8.0_112" class="java.beans.XMLDecoder">
<object class="simple.Simple">
<void property="n">
<int>7</int>
</void>
</object>
</java>
在这里,我们看到XMLENCODER输出唯一一个属性,而对象的先前打印输出显示两个属性都设置了其值。好像Xmlencoder有一个水晶球,并且知道过去发生了什么!
它实际上看起来相反,好像它有失忆症一样,它可以同时输出N和M,但它确实只打印了一个属性,该属性受您的设定器的影响。
但官方Doc说
结构紧凑:xmlencoder类使用冗余 内部消除算法,以便 Bean的属性未写入流。
因此,它解释了其选择性