爲何要作序列化和反序列化?html
.Net程序執行時,對象都駐留在內存中;內存中的對象若是須要傳遞給其餘系統使用;或者在關機時須要保存下來以便下次再次啓動程序使用就須要序列化和反序列化。測試
一段最簡單的Xml序列化代碼spa
C# 代碼 複製code
class Program{ static void Main(string[] args) { int i = 10; //聲明Xml序列化對象實例serializer XmlSerializer serializer = new XmlSerializer(typeof(int)); //執行序列化並將序列化結果輸出到控制檯 serializer.Serialize(Console.Out, i); Console.Read(); }}
上面代碼對int i進行了序列化,並將序列化的結果輸出到了控制檯,輸出結果以下orm
<?xml version="1.0" encoding="gb2312"?> <int>10</int>
將上述序列化的xml進行反序列化,以下代碼xml
C# 代碼 複製htm
static void Main(string[] args){ using (StringReader rdr = new StringReader(@"<?xml version=""1.0"" encoding=""gb2312""?><int>10</int>")) { //聲明序列化對象實例serializer XmlSerializer serializer = new XmlSerializer(typeof(int)); //反序列化,並將反序列化結果值賦給變量i int i = (int)serializer.Deserialize(rdr); //輸出反序列化結果 Console.WriteLine("i = " + i); Console.Read(); }}
以上代碼用最簡單的方式說明了xml序列化和反序列化的過程,.Net系統類庫爲咱們作了大量的工做,序列化和反序列化都很是簡單。可是在現實中業務需求每每比較複雜,不可能只簡單的序列化一個int變量,顯示中咱們須要對複雜類型進行可控制的序列化。對象
System.Xml.Serialization類爲咱們提供了本身對象串行化(Serialize)和反串行化(Deserialize)的xml的方法,該類能夠序列化的內容:內存
公共類的公共讀寫字段或者屬性
XmlElement對象
XmlNode對象
Dataset對象
實現了Icollection 或IEnumerable的類ci
下面介紹 XML序列化和反序列化 封裝類
C# 代碼 複製
using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.IO;using System.Data;using System.Xml;using System.Xml.Serialization; /// <summary>/// Xml序列化與反序列化/// </summary>public class XmlUtil{ #region 反序列化 /// <summary> /// 反序列化 /// </summary> /// <param name="type">類型</param> /// <param name="xml">XML字符串</param> /// <returns></returns> public static object Deserialize(Type type, string xml) { try { using (StringReader sr = new StringReader(xml)) { XmlSerializer xmldes = new XmlSerializer(type); return xmldes.Deserialize(sr); } } catch (Exception e) { return null; } } /// <summary> /// 反序列化 /// </summary> /// <param name="type"></param> /// <param name="xml"></param> /// <returns></returns> public static object Deserialize(Type type, Stream stream) { XmlSerializer xmldes = new XmlSerializer(type); return xmldes.Deserialize(stream); } #endregion 序列化}
該封裝類的測試代碼
1. 實體對象轉換到Xml
C# 代碼 複製
public class Student{ public string Name { set; get; } public int Age { set; get; }} Student stu1 = new Student() { Name = "okbase", Age = 10 };string xml = XmlUtil.Serializer(typeof(Student), stu1);Console.Write(xml);
2. Xml轉換到實體對象
Student stu2 = XmlUtil.Deserialize(typeof(Student), xml) as Student;
Console.Write(string.Format("名字:{0},年齡:{1}", stu2.Name, stu2.Age));
三、DataTable轉換到Xml
C# 代碼 複製
// 生成DataTable對象用於測試DataTable dt1 = new DataTable("mytable"); // 必須指明DataTable名稱 dt1.Columns.Add("Dosage", typeof(int));dt1.Columns.Add("Drug", typeof(string));dt1.Columns.Add("Patient", typeof(string));dt1.Columns.Add("Date", typeof(DateTime)); // 添加行dt1.Rows.Add(25, "Indocin", "David", DateTime.Now);dt1.Rows.Add(50, "Enebrel", "Sam", DateTime.Now);dt1.Rows.Add(10, "Hydralazine", "Christoff", DateTime.Now);dt1.Rows.Add(21, "Combivent", "Janet", DateTime.Now);dt1.Rows.Add(100, "Dilantin", "Melanie", DateTime.Now); // 序列化xml = XmlUtil.Serializer(typeof(DataTable), dt1);Console.Write(xml);
4. Xml轉換到DataTable
C# 代碼 複製
// 反序列化DataTable dt2 = XmlUtil.Deserialize(typeof(DataTable), xml) as DataTable; // 輸出測試結果foreach (DataRow dr in dt2.Rows){ foreach (DataColumn col in dt2.Columns) { Console.Write(dr[col].ToString() + " "); } Console.Write("\\r\\n");}
5. List轉換到Xml
C# 代碼 複製
// 生成List對象用於測試List<Student> list1 = new List<Student>(3); list1.Add(new Student() { Name = "okbase", Age = 10 });list1.Add(new Student() { Name = "csdn", Age = 15 });// 序列化xml = XmlUtil.Serializer(typeof(List<Student>), list1);Console.Write(xml);
6. Xml轉換到List
C# 代碼 複製
List<Student> list2 = XmlUtil.Deserialize(typeof(List<Student>), xml) as List<Student>;foreach (Student stu in list2){ Console.WriteLine(stu.Name + "," + stu.Age.ToString());}