xml反序列化:NET对象的XML序列化和反序列化(一)来源: 发布时间:星期一, 2008年10月20日 浏览:160次 评论:0
想飞的石头
.NET对象的XML序列化和反序列化 序列化的概念 序列化是指一个对象的实例可以被保存,保存成一个二进制串,当然,一旦被保存成二进制串,那么也可以保存成文本串了。 比如,一个计数器,数值为2,我们可以用字符串“2”表示。 如果有个对象,叫做connter,当前值为2,那么可以序列化成“2”,反向的,也可以从“2”得到值为2的计数器实例。 这样,关机时序列化它,开机时反序列化它,每次开机都是延续的。不会都是从头开始。 序列化概念的提出和实现,可以使我们的应用程序的设置信息保存和读取更加方便。 序列化有很多好处,比如,在一台机器上产生一个实例,初始化完毕,然后可以序列化,通过网络传送到另一台机器,然后反序列化,得到对象实例,之后再执行某些业务逻辑,得到结果,再序列化,返回第一台机器,第一台机器得到对象实例,得到结果。 这个例子是目前比较先进的“智能代理”的原理。 当前比较热火的web services使用soap协议,soap协议也是以对象的可序列化为基础的。 一 概述 .NET Framework为处理XML数据提供了许多不同的类库。XmlDocument类能让你像处理文件一样处理xml数据,而XmlReader、XmlWriter和它们的派生类使你能够将xml数据作为数据流处理。 XmlSerializer则提供了另外的方法,它使你能够将自己的对象串行化和反串行化为xml。串行化数据既能够让你像处理文件一样对数据进行随机处理,同时又能跳过你不感兴趣的数据。 二 主要类库介绍 .NET 支持对象xml序列化和反序列化的类库主要位于命名空间System.Xml.Serialization中。 1. XmlSerializer 类 该类用一种高度松散耦合的方式提供串行化服务。你的类不需要继承特别的基类,而且它们也不需要实现特别的接口。相反,你只需在你的类或者这些类的公共域以及读/写属性里加上自定义的特性。XmlSerializer通过反射机制读取这些特性并用它们将你的类和类成员映射到xml元素和属性。 2. XmlAttributeAttribute 类 指定类的公共域或读/写属性对应xml文件的Attribute。 例:[XmlAttribute(“type”)] or [XmlAttribute(AttributeName=”type”)] 3. XmlElementAttribute类 指定类的公共域或读/写属性对应xml文件的Element。 例:[XmlElement(“Maufacturer”)] or [XmlElement(ElementName=”Manufacturer”)] 4. XmlRootAttribute类 Xml序列化时,由该特性指定的元素将被序列化成xml的根元素。 例:[XmlRoot(“RootElement”)] or [XmlRoot(ElementName = “RootElements”)] 5. XmlTextAttribute 类 Xml序列化时,由该特性指定的元素值将被序列化成xml元素的值。一个类只允许拥有一个该特性类的实例,因为xml元素只能有一个值。 6. XmlIgnoreAttribute类 Xml序列化时不会序列化该特性指定的元素。 三 实例 下面例子中的xml schema 描述了一个简单的人力资源信息,其中包含了xml的大部分格式,如xml 元素相互嵌套, xml元素既有元素值,又有属性值。 1. 待序列化的类层次结构 [XmlRoot("humanResource")] public class HumanResource { #region private data. private int m_record = 0; private Worker[] m_workers = null; #endregion [XmlAttribute(AttributeName="record")] public int Record { get { return m_record; } set { m_record = value; } } [XmlElement(ElementName="worker")] public Worker[] Workers { get { return m_workers; } set { m_workers = value; } } } public class Worker { #region private data. private string m_number = null; private InformationItem[] m_infoItems = null; #endregion [XmlAttribute("number")] public string Number { get { return m_number; } set { m_number = value; } } [XmlElement("infoItem")] public InformationItem[] InfoItems { get { return m_infoItems; } set { m_infoItems = value; } } } public class InformationItem { #region private data. private string m_name = null; private string m_value = null; #endregion [XmlAttribute(AttributeName = "name")] public string Name { get { return m_name; } set { m_name = value; } } [XmlText] public string Value { get { return m_value; } set { m_value = value; } } } 2. 序列化生成的xml结构 <?xml version="1.0" ?> - <humanResource xmlns:xsi=" 1. 需要序列化为xml元素的属性必须为读/写属性; 2. 注意为类成员设定缺省值,尽管这并不是必须的。 有关.NET中序列化的一些知识 “序列化”可被定义为将对象的状态存储到存储媒介中的过程。在此过程中,对象的公共字段和私有字段以及类的名称(包括包含该类的程序集)都被转换为字节流,然后写入数据流。在以后“反序列化”该对象时,创建原始对象的精确复本。 一、为什么要选择序列化 一个原因是将对象的状态保持在存储媒体中,以便可以在以后重新创建精确的副本; 另一个原因是通过值将对象从一个应用程序域发送到另一个应用程序域中。 例如,序列化可用于在 ASP.NET 中保存会话状态并将对象复制到 Windows 窗体的剪贴板中。远程处理还可以使用序列化通过值将对象从一个应用程序域传递到另一个应用程序域中。 二、如何实现对象的序列化及反序列化 要实现对象的序列化,首先要保证该对象可以序列化。而且,序列化只是将对象的属性进行有效的保存,对于对象的一些方法则无法实现序列化的。 实现一个类可序列化的最简便的方法就是增加Serializable属性标记类。如: [Serializable()] public class MEABlock { private int m_ID; public string Caption; public MEABlock() { ///构造函数 } } 即可实现该类的可序列化。 0
相关文章
读者评论
发表评论 |