- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我祈祷有人对 Microsoft XmlSerializer 有很好的理解。
基本上,我已经构建了一个系统用于在序列化程序的背面输出 XML,这现在给我带来了很多麻烦,我正在努力避免重大的重写。
我当前的系统使用了很多派生类。
例如,
BaseResponse -> CarParkResponse -> CarParkResponseInherited
BaseResponse 和 CarParkResponse(都在库 dll 中)与 CarParkResponseInherited 是分开的。
因此,基类会忽略派生类。
-> 声明派生类
我很欣赏,为了让 xmlserializer 完成它的工作,有很多方法可以声明派生类。
或
XmlSerializer serializer = new XmlSerializer(typeof(CarParkResponse), new Type[] { typeof(CarParkParameters), typeof(CarParkInformation) });
我选择了后者。
因为派生类是独立的并且它们共享相同的属性,所以我要做的是将派生类序列化为子类。
换句话说,将 CarParkResponseInherited 反序列化为 CarParkResponse。
在“CarParkResponseInherited”中,我使用声明 XmlTypeAttribute("CarParkResponse")。
最初这会在序列化时引起问题
Types 'CarParkResponseInherited' and 'CarParkResponse' both use the XML type name, 'CarParkResponse', from namespace ''. Use XML attributes to specify a unique XML name and/or namespace for the type."
因为类型已经在使用“CarParkResponse”,所以我在“CarParkResponse”中声明了 XmlType(“Response”) 来解决这个问题。
我现在正在尝试反序列化返回的 XML,但我现在遇到了以下问题。
The specified type was not recognized: name='CarParkResponse', namespace='', at OriginalRequest xmlns=''
令人沮丧的是,CarParkResponse 就在那里。我想知道这是否是因为我在类中使用了 XmlType("Response") 并且序列化程序没有将该类识别为 CarParkResponse 类型
基本上是否可以将派生类作为子类传递并使用 XmlSerializer 将其反序列化为子类?
我已经对生成的 xml 进行了试验。
例如,如果我不在代码中的任何地方使用序列化标记(例如 XmlType() 等)。生成的 xml 将生成一个带有“type”作为属性的 carparkresponse 元素。
值为“CarParkResponseInherited”。我已经编写了一些代码,从值中删除“继承”,这确实允许它被反序列化。
这种方法显然不好,所以我希望有一个好的方法来解决这个问题。
如果有人必须耐心阅读这篇文章并且可以提供帮助或提供建议,那将不胜感激,因为我完全没有想法。
谢谢。
最佳答案
使用 XmlAttributeOverrides 类可能会做一些事情。它主要用于特定的属性覆盖,因此它可能是也可能不是最适合您的东西。
很长的路要走,将其序列化为继承的类。然后,如果映射相同,则将 xml 反序列化为基类,然后,重新序列化为您想要的。
根据您对程序集的控制程度,您可以覆盖继承类的序列化,使其作为基类执行。
关于c# - XMLSerializer : Deserializing as derived type,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8096360/
我在 Ubuntu 11.10 和最新版本的 NetBeans 下使用 C++。假设我有以下代码: class Node {} class DerivedNode : public Node {} c
这两者在 GHC 中有什么区别。它们的预期用途似乎相似,但 deriving (Data)已经存在了一段时间了deriving (Generic)最近才添加到 GHC 中。 是 deriving (G
当您将矩阵对象作为 MatrixBase 引用传递给函数时会发生什么?我不明白幕后到底发生了什么。 示例函数代码如下: #include #include using namspace Eigen
我正在尝试了解如何在 Eigen 中使用样条曲线,特别是我想在某个点上找到样条插值及其一阶和二阶导数的值。找到内插值很容易,但是当我尝试计算导数时,我得到了奇怪的值。 我尝试按照手册 ( http:/
使用 C++ Builder XE7 我有一个带有 TImageList 对象的基本表单 object FormBase: TFormBase Left = 0 Top = 0 Capti
我正在制作基类和派生类。派生类的值将为 Eigen::Matrix , 并继承了 Base 的所有方法。 我这样做是为了使无论矩阵类型如何都相同的方法不会因为 Matrix 的不同模板参数而全部重复。
我最近更新到最新的 Eigen 版本 (3.3.90),看起来它破坏了我之前工作的东西(在我使用 libigl 库附带的 Eigen 版本 3.2.10 之前)。 我想将 block 的结果存储到一个
我最近一直在尝试“向我学习 Haskell”,我想创建一个新类型来表示整数状态,而不仅仅是使用原始 Integer(为了类型安全和代码清晰)。具体来说,以下代码编译: newtype AuxState
这个问题已经有答案了: Access subclass fields from a base class in Java (4 个回答) 已关闭 4 年前。 我对 Java 和面向对象编程总体来说是新
我有这些类,事件记录模式的实现: public abstract class RecordCollection : ObservableCollection where T : Record publ
首先,这个问题非常类似于 downcasting shared pointer to derived class with additional functionality is ,哪里有好的答案。但
好的,我正在通读 this entry in the FQA处理将 Derived** 转换为 Base** 的问题以及为什么它被禁止,我得到的问题是你可以分配给 Base* 不是 Derived*
我正在使用 Boost.Python 将我的 C++ 代码公开给 Python。我遇到了与将对象从一种语言多次传递到另一种语言有关的困难。这是我想要做的: C++代码 class Base { p
这个问题在这里已经有了答案: Downcasting using the 'static_cast' in C++ (3 个答案) 关闭 8 年前。 我不明白为什么会这样。pReallyABase
https://sqlzoo.net/wiki/SELECT_within_SELECT_Tutorial 的问题 7 “找到每个大陆中最大的国家(按面积),显示大陆、名称和面积:” 我不明白为什么
我很难理解为什么以下代码无法编译: template class Base { public: Base(int a){} }; template class Derive
我很难理解为什么以下代码无法编译: template class Base { public: Base(int a){} }; template class Derive
Base to Derived 是可能的(装箱)。但是 Derived to base 给出了运行时异常,然而这相当于拆箱。为什么会这样 Base b = new Base(); Child c =
库代码 我的图书馆有一个 CRTP 类 B . 我创建了一个 Trait使用户能够更改 B 行为的类. 默认设置为 int . ( #1 ) #include #include //B and T
我正在学习 C++ 继承,所以我通过动态创建一个 Base 类来尝试这段代码,并对它的 Derived 类进行向下转换(显然向下转换无效)以使这个动态创建的 Base 对象被指向派生类指针。但是当我通
我是一名优秀的程序员,十分优秀!