当前位置: 首页 > 编程笔记 >

C#中将xml文件反序列化为实例时采用基类还是派生类的知识点讨论

况博容
2023-03-14
本文向大家介绍C#中将xml文件反序列化为实例时采用基类还是派生类的知识点讨论,包括了C#中将xml文件反序列化为实例时采用基类还是派生类的知识点讨论的使用技巧和注意事项,需要的朋友参考一下

基类:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace DeserializeTest
{
 public class SettingsBase
 {
 private string m_fileName;

 public string FileName 
 {
  get { return m_fileName; }
  set { m_fileName = value; }
 }
  
 }
}

派生类:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace DeserializeTest
{
 public class WorldWindSettings : SettingsBase
 {
  public WorldWindSettings()
   : base()
  {
  }


  private string m_proxyUrl = "";

  public string ProxyUrl
  {
   get
   {
    return m_proxyUrl;
   }
   set
   {
    this.m_proxyUrl = value;
   }
  }
 }
}

主函数调用测试代码为:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

using System.IO;
using System.Xml.Serialization;

namespace DeserializeTest
{
 class Program
 {
  static void Main(string[] args)
  {
   //测试1:测试将xml文件反序列化为基类实例。测试通过。只要xml文件的根节点的名字与被反序列化的类的名字一致即可
   string fileNameBase = @"D:\MyProject\DeserializeTest\DeserializeTest\bin\Debug\GobalConfig\SettingsBase.xml";
   SettingsBase settingsBase;
   XmlSerializer serBase = new XmlSerializer(typeof(SettingsBase));
   using (TextReader trBase = new StreamReader(fileNameBase))
   {
    settingsBase = (SettingsBase)serBase.Deserialize(trBase);
    settingsBase.FileName = fileNameBase;
   }

   //测试2:测试将xml文件反序列化为子类实例。测试通过。只要xml文件的根节点的名字与被反序列化的类的名字一致即可。当然了,用基类的实例引用去指向反序列化后的派生类的实例也是没问题的。
   string fileName = @"D:\MyProject\DeserializeTest\DeserializeTest\bin\Debug\GobalConfig\WorldWind.xml";
   SettingsBase settings;//当前了此处定义为WorldWindSettings settings;也没问题
   Type type = typeof(WorldWindSettings);//因为xml文件的根节点名称是WorldWindSettings,此处只能为WorldWindSettings,而不能为SettingsBase
   XmlSerializer ser = new XmlSerializer(type);
   using (TextReader tr = new StreamReader(fileName))
   {
    //settings = (WorldWindSettings)ser.Deserialize(tr);//这两句代码都可以通过!
    settings = (SettingsBase)ser.Deserialize(tr);
    settings.FileName = fileName;
   }

   System.Console.WriteLine("Hello");
  }
 }
}

基类的XML文件:

<?xml version="1.0" encoding="utf-8"?>
<SettingsBase>
 <FileName>WorldWind.xml</FileName>
</SettingsBase>

派生类的XML文件:

<?xml version="1.0" encoding="utf-8"?>
<WorldWindSettings>
 <FileName>WorldWind.xml</FileName>
 <ProxyUrl>www.baidu.com</ProxyUrl>
</WorldWindSettings>

源码下载:DeserializeTest.rar 提取码:djpe

总结:将xml文件反序列化为类的实例的时候,只要xml文件的根节点的名字与被反序列化的类的名字一致即可。当然了,反序列化成功后,用基类的实例引用去指向反序列化后的派生类的实例也是没问题的。

其它注意事项:

如果在一个类中有静态的成员变量,则在该类调用构造函数实例化之前,会首先实例化静态的成员变量。

以上就是本次介绍的全部知识点内容,感谢大家的学习和对小牛知识库的支持。

 类似资料:
  • 我有一个通过RabbitMQ作为消息发送的类,在sender服务上,它的定义如下: 并且在接收方服务上: 在receiver controller中,我有以下方法,它应该接受该消息,将其转换为一个对象,并将其保存在数据库中,看起来如下所示: 编辑:根据请求添加堆栈跟踪。

  • 我试图反序列化2种不同类型的列表,包括它们的派生类 为了更好地解释它,我做了下面的例子 我有2个系统: API系统 与下列实体合作: 应用系统 使用以下DTO 使用此示例,API系统返回一个

  • 问题内容: 我正在尝试创建类实例的JSON字符串表示形式并且遇到困难。假设该类的构建如下: 像这样对json.dumps进行调用: 失败了,并告诉我testclass不可JSON序列化。 我也尝试过使用pickle模块: 它提供类实例信息,但不提供类实例的序列化内容。 我究竟做错了什么? 问题答案: 基本问题是,JSON编码器仅知道默认情况下如何序列化一组有限的对象类型(所有内置类型)。在此处列出

  • 我有一个带有Object类型属性的基类型(一段遗留代码,许多项目都使用这个基类型)。后来添加了基类型的泛型版本,将属性公开为泛型类型。 使用ServiceStack.Text序列化和反序列化泛型类型将设置基类(type object)上的属性,而不是派生类上更特定的类型。 重现错误的简单控制台应用程序如下所示: 感谢任何帮助。 基于这个答案,我通过使和从一个新的抽象基类继承来解决这个问题,如下所示