您的位置:首页 > 编程语言 > C#

深入C#学习系列一:序列化(Serialize)、反序列化(Deserialize)

2008-01-13 20:29 746 查看
序列化又称串行化,是.NET运行时环境用来支持用户定义类型的流化的机制。其目的是以某种存储形成使自定义对象持久化,或者将这种对象从一个地方传输到另一个地方。

.NET框架提供了两种串行化的方式:1、是使用BinaryFormatter进行串行化;2、使用SoapFormatter进行串行化;3、使用XmlSerializer进行串行化。第一种方式提供了一个简单的二进制数据流以及某些附加的类型信息,而第二种将数据流格式化为XML存储;第三种其实和第二种差不多也是XML的格式存储,只不过比第二种的XML格式要简化很多(去掉了SOAP特有的额外信息)。

可以使用[Serializable]属性将类标志为可序列化的。如果某个类的元素不想被序列化,1、2可以使用[NonSerialized]属性来标志,2、可以使用[XmlIgnore]来标志。

1、使用BinaryFormatter进行串行化

下面是一个可串行化的类:

using System;

using System.Data;

using System.Configuration;

using System.Web;

using System.Web.Security;

using System.Web.UI;

using System.Web.UI.WebControls;

using System.Web.UI.WebControls.WebParts;

using System.Web.UI.HtmlControls;

using System.IO;

using
System.Runtime.Serialization.Formatters.Binary;

[Serializable]

public class ClassToSerialize

下面是串行化和反串行化的方法:

public void SerializeNow()

public void DeSerializeNow()

using System;

using System.Data;

using System.Configuration;

using System.Web;

using System.Web.Security;

using System.Web.UI;

using System.Web.UI.WebControls;

using System.Web.UI.WebControls.WebParts;

using System.Web.UI.HtmlControls;

using System.Xml.Serialization;

[Serializable]

public class Person

[Serializable]

public class Course

序列化和反序列化方法:

public void XMLSerialize()

public void XMLDeserialize()

<?xml version="1.0"?>

<Person xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">

<Sex>男</Sex>

<Age>31</Age>

<Courses>

<Course>

<Name>英语</Name>

<Description>交流工具</Description>

</Course>

<Course>

<Name>数学</Name>

<Description>自然科学</Description>

</Course>

</Courses>

<Name>cyj</Name>

</Person>

4、自定义序列化

如果你希望让用户对类进行串行化,但是对数据流的组织方式不完全满意,那么可以通过在自定义类中实现接口来自定义串行化行为。这个接口只有一个方法,GetObjectData. 这个方法用于将对类对象进行串行化所需要的数据填进SerializationInfo对象。你使用的格式化器将构造SerializationInfo对象,然后在串行化时调用GetObjectData. 如果类的父类也实现了ISerializable,那么应该调用GetObjectData的父类实现。

如果你实现了ISerializable,那么还必须提供一个具有特定原型的构造器,这个构造器的参数列表必须与GetObjectData相同。这个构造器应该被声明为私有的或受保护的,以防止粗心的开发人员直接使用它。

示例如下:

实现ISerializable的类:

using System;

using System.Data;

using System.Configuration;

using System.Web;

using System.Web.Security;

using System.Web.UI;

using System.Web.UI.WebControls;

using System.Web.UI.WebControls.WebParts;

using System.Web.UI.HtmlControls;

using System.Runtime.Serialization;

using System.Runtime.Serialization.Formatters.Binary;

[Serializable]

public class Employee:ISerializable

序列化和反序列化方法:

public void OtherEmployeeClassTest()

{

Employee mp = new Employee();

mp.EmpId = 10;

mp.EmpName = "邱枫";

mp.NoSerialString = "你好呀";

Stream steam = File.Open("c:\\temp3.dat", FileMode.Create);

BinaryFormatter bf = new BinaryFormatter();

Response.Write("Writing Employee Info:");

bf.Serialize(steam,mp);

steam.Close();

mp = null;

//反序列化

Stream steam2 = File.Open("c:\\temp3.dat", FileMode.Open);

BinaryFormatter bf2 = new BinaryFormatter();

Response.Write("Reading Employee Info:");

Employee mp2 = (Employee)bf2.Deserialize(steam2);

steam2.Close();

Response.Write(mp2.EmpId);

Response.Write(mp2.EmpName);

Response.Write(mp2.NoSerialString);

}

PS:本文章属个人学习总结,部分内容参考互联网上的相关文章。 其中如果发现个人总结有不正确的认知或遗漏的地方请评论告知,欢迎交流。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐