我想像下面的类一样对一个方法输出进行serlialize。
@Root
public class Camera {
public enum Mode {
CONTINIOUS, TRIGGERED, DEACTIVATED;
}
@Element
private Mode currMode;
@Element
private int interval;
@Element
private int beforeEvent;
@Element
private int afterEvent;
@Element
private String savePath;
public Camera(Mode currMode, int interval, int beforeEvent, int afterEvent,
String savePath) {
super();
this.currMode = currMode;
this.interval = interval;
this.beforeEvent = beforeEvent;
this.afterEvent = afterEvent;
this.savePath = savePath;
}
@ElementList(entry = "mode", name = "availableModes")
public ArrayList<Mode> getAvailableModes() {
return new ArrayList<Mode>(Arrays.asList(Mode.values()));
}
}
该方法将枚举的所有可能性返回为List。 如果未设置默认构造函数,则序列化将成功完成。
<camera>
<savePath>/images</savePath>
<currMode>CONTINIOUS</currMode>
<beforeEvent>5000</beforeEvent>
<interval>3000</interval>
<afterEvent>10000</afterEvent>
<availableModes>
<mode>CONTINIOUS</mode>
<mode>TRIGGERED</mode>
<mode>DEACTIVATED</mode>
</availableModes>
</camera>
但是,反序列化需要默认构造函数。 如果我设置了默认构造函数,则在序列化和反序列化过程中会出现以下错误。
Default constructor can not accept read only @org.simpleframework.xml.ElementList(data=false, empty=true, entry=mode, inline=false, name=availableModes, required=false, type=void) on method 'availableModes' in class Camera
在反序列化期间,应忽略anotated方法。是否有可能定义一个元素,它将在序列化过程中被考虑,并且在反序列化过程中将被忽略?
答案 0 :(得分:1)
你需要确保有一些设置列表的方法,你可以为列表添加一个setter,或者你可以像这样使用构造函数注入。
public Camera(
@Element(name="currMode") Mode currMode,
@Element(name="interval") int interval,
@Element(name="beforeEvent") int beforeEvent,
@Element(name="afterEvent") int afterEvent,
@Element(name="savePath") String savePath,
@ElementList(name="availableModes") List<Mode> availableModes)
{
this.currMode = currMode;
this.interval = interval;
this.beforeEvent = beforeEvent;
this.afterEvent = afterEvent;
this.savePath = savePath;
}
无论如何,XML序列化过程需要知道它应该在元素“availableMode”中找到它的值。