xmlencoder writeObject跳过构造器中初始化的属性



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的属性未写入流。

因此,它解释了其选择性

相关内容

  • 没有找到相关文章

最新更新