gpt4 book ai didi

java - 为什么 XMLDecoder 不遵守 transient 关键字?

转载 作者:行者123 更新时间:2023-11-30 08:20:39 27 4
gpt4 key购买 nike

Java 有一个 transient 关键字,它与默认序列化一起使用以指示不应序列化的值。但是,如果我将 XML 序列化与 XMLDecoder 结合使用,则与该字段关联的属性仍会被序列化。我在 JSON 中使用 Gson 库进行了相同的尝试, transient 字段似乎确实被正确跳过了。

有什么想法吗?

最佳答案

XML 编码器/解码器偏爱 @XMLTransient注释。

transient 关键字用于以字节序列结束的 java 对象序列化过程。 XML“序列化”以格式化的文本文档结束。当您选择不序列化的字段(通过将其标记为 transient)时可能会有不同的方面,并且由于输出完全不同,您可能想要选择要排除的不同字段并自行处理它们。例如,在 Java 序列化的情况下,您可能希望选择序列化 byte[],因为它简单明了。在 XML 的情况下,如果它具有更好/更有意义的文本表示,您可能希望序列化用于创建该字节数组的对象。

@XMLTransientJAXB 使用.对于 XMLEncoder 排除字段(将其标记为 transient ),您必须在其 PropertyDescriptor 中将 “transient” 属性设置为 TRUE :(source)

BeanInfo info = Introspector.getBeanInfo(JTextField.class);
PropertyDescriptor[] propertyDescriptors =
info.getPropertyDescriptors();
for (int i = 0; i < propertyDescriptors.length; ++i) {
PropertyDescriptor pd = propertyDescriptors[i];
if (pd.getName().equals("text")) {
pd.setValue("transient", Boolean.TRUE);
}
}

这不是一个优雅的解决方案。另一种方法是使用 JAXB而不是 XMLEncoder

关于java - 为什么 XMLDecoder 不遵守 transient 关键字?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25889719/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com