c#对象反序列化与对象序列化示例详解

1.对象序列化的介绍

(1).NET支持对象序列化的几种方式
二进制序列化:对象序列化之后是二进制形式的,通过BinaryFormatter类来实现的,这个类位于System.Runtime.Serialization.Formatters.Binary命名空间下。
SOAP序列化:对象序列化之后的结果符合SOAP协议,也就是可以通过SOAP 协议传输,通过System.Runtime.Serialization.Formatters.Soap命名空间下的SoapFormatter类来实现的。
XML序列化:对象序列化之后的结果是XML形式的,通过XmlSerializer 类来实现的,这个类位于System.Xml.Serialization命名空间下。XML序列化不能序列化私有数据。

(2)几种序列化的区别
二进制格式和SOAP格式可序列化一个类型的所有可序列化字段,不管它是公共字段还是私有字段。XML格式仅能序列化公共字段或拥有公共属性的私有字段,未通过属性公开的私有字段将被忽略。
使用二进制格式序列化时,它不仅是将对象的字段数据进行持久化,也持久化每个类型的完全限定名称和定义程序集的完整名称(包括包称、版本、公钥标记、区域性),这些数据使得在进行二进制格式反序列化时亦会进行类型检查。SOAP格式序列化通过使用XML命名空间来持久化原始程序集信息。而XML格式序列化不会保存完整的类型名称或程序集信息。这便利XML数据表现形式更有终端开放性。如果希望尽可能延伸持久化对象图的使用范围时,SOAP格式和XML格式是理想选择。
(3)使用特性对序列化的控制
要让一个对象支持.Net序列化服务,用户必须为每一个关联的类加上[Serializable]特性。如果类中有些成员不适合参与序列化(比如:密码字段),可以在这些域前加上[NonSerialized]特性。

2.使用二进制序列化和反序列化

(1)二进制序列化与反序列化的程序示例

代码如下:

[Serializable]  //必须添加序列化特性
    public class Person
    {
        private string Name;//姓名
        private bool Sex;//性别,是否是男
        public Person(string name, bool sex)
        {
            this.Name = name;
            this.Sex = sex;
        }
        public override string ToString()
        {
            return "姓名:" + this.Name + "\t性别:" + (this.Sex ? "男" : "女");
        }
    }
    [Serializable]  //必须添加序列化特性
    public class Programmer : Person
    {
        private string Language;//编程语言
        public Programmer(string name, bool sex, string language) : base(name, sex)
        {
            this.Language = language;
        }
        public override string ToString()
        {
            return base.ToString() + "\t编程语言:" + this.Language;
        }
    }
    class Program
    {
        static void Main(string[] args)
        {
            //创建Programmer列表,并添加对象
            List<Programmer> list = new List<Programmer>();
            list.Add(new Programmer("李志伟", true, "C#"));
            list.Add(new Programmer("Coder2", false, "C++"));
            list.Add(new Programmer("Coder3", true, "Java"));
            //使用二进制序列化对象
            string fileName = @"D:\users\lizw\桌面\Programmers.dat";//文件名称与路径
            Stream fStream = new FileStream(fileName, FileMode.Create, FileAccess.ReadWrite);
            BinaryFormatter binFormat = new BinaryFormatter();//创建二进制序列化器
            binFormat.Serialize(fStream, list);
            //使用二进制反序列化对象
            list.Clear();//清空列表
            fStream.Position = 0;//重置流位置
            list = (List<Programmer>)binFormat.Deserialize(fStream);//反序列化对象
            foreach (Programmer p in list)
            {
                Console.WriteLine(p);
            }
            Console.Read();
        }
    }

(2)总结
使用二进制序列化,必须为每一个要序列化的的类和其关联的类加上[Serializable]特性,对类中不需要序列化的成员可以使用[NonSerialized]特性。
二进制序列化对象时,能序列化类的所有成员(包括私有的),且不需要类有无参数的构造方法。
使用二进制格式序列化时,它不仅是将对象的字段数据进行持久化,也持久化每个类型的完全限定名称和定义程序集的完整名称(包括包称、版本、公钥标记、区域性),这些数据使得在进行二进制格式反序列化时亦会进行类型检查。所以反序列化时的运行环境要与序列化时的运行环境要相同,否者可能会无法反序列化成功。
3.使用SOAP方式序列化和反序列化
(1)SOAP序列化与反序列化的程序示例

代码如下:

[Serializable]  //必须添加序列化特性
    public class Person
    {
        private string Name;//姓名
        private bool Sex;//性别,是否是男
        public Person(string name, bool sex)
        {
            this.Name = name;
            this.Sex = sex;
        }
        public override string ToString()
        {
            return "姓名:" + this.Name + "\t性别:" + (this.Sex ? "男" : "女");
        }
    }
    [Serializable]  //必须添加序列化特性
    public class Programmer : Person
    {
        private string Language;//编程语言
        public Programmer(string name, bool sex, string language) : base(name, sex)
        {
            this.Language = language;
        }
        public override string ToString()
        {
            return base.ToString() + "\t编程语言:" + this.Language;
        }
    }
    class Program
    {
        static void Main(string[] args)
        {
            //实例化对象
            Programmer p = new Programmer("李志伟", true, "C、C#、C++、Java");
            //使用SOAP序列化对象
            string fileName = @"D:\users\lizw\桌面\Programmers.xml";//文件名称与路径
            Stream fStream = new FileStream(fileName, FileMode.Create, FileAccess.ReadWrite);
            SoapFormatter soapFormat = new SoapFormatter();//创建SOAP序列化器
            soapFormat.Serialize(fStream, p);//SOAP不能序列化泛型对象
            //使用SOAP反序列化对象
            fStream.Position = 0;//重置流位置
            p = null;
            p = (Programmer)soapFormat.Deserialize(fStream);
            Console.WriteLine(p);
            Console.Read();
        }
    }

(2)总结
SOAP序列化与二进制序列化的区别是:SOAP序列化不能序列化泛型类型。与二进制序列化一样在序列化时不需要向序列化器指定序列化对象的类型。而XML序列化需要向XML序列化器指定序列化对象的类型。
4.使用XML方式序列化和反序列化
(1)XML序列化与反序列化的程序示例

代码如下:

public class Person
    {
        public string Name;//姓名
        public bool Sex;//性别,是否是男
        public Person() { }//必须提供无参构造器,否则XmlSerializer将出错
        public Person(string name, bool sex)
        {
            this.Name = name;
            this.Sex = sex;
        }
        public override string ToString()
        {
            return "姓名:" + this.Name + "\t性别:" + (this.Sex ? "男" : "女");
        }
    }
    public class Programmer : Person
    {
        public string Language;//编程语言
        public Programmer() { }//必须提供无参构造器,否则XmlSerializer将出错
        public Programmer(string name, bool sex, string language) : base(name, sex)
        {
            this.Language = language;
        }
        public override string ToString()
        {
            return base.ToString() + "\t编程语言:" + this.Language;
        }
    }
    class Program
    {
        static void Main(string[] args)
        {
            //创建Programmer列表,并添加对象
            List<Programmer> list = new List<Programmer>();
            list.Add(new Programmer("李志伟", true, "C#"));
            list.Add(new Programmer("Coder2", false, "C++"));
            list.Add(new Programmer("Coder3", true, "Java"));
            //使用XML序列化对象
            string fileName = @"D:\users\lizw\桌面\Programmers.xml";//文件名称与路径
            Stream fStream = new FileStream(fileName, FileMode.Create, FileAccess.ReadWrite);
            XmlSerializer xmlFormat = new XmlSerializer(
typeof(List<Programmer>),
new Type[] { typeof(Programmer),typeof(Person) }
);//创建XML序列化器,需要指定对象的类型
            xmlFormat.Serialize(fStream, list);
            //使用XML反序列化对象
            fStream.Position = 0;//重置流位置
            list.Clear();
            list = (List<Programmer>)xmlFormat.Deserialize(fStream);
            foreach (Programmer p in list)
            {
                Console.WriteLine(p);
            }
            Console.Read();
        }
    }

(2)总结
使用XML序列化或反序列化时,需要对XML序列化器指定需要序列化对象的类型和其关联的类型。
XML序列化只能序列化对象的公有属性,并且要求对象有一个无参的构造方法,否者无法反序列化。
[Serializable]和[NonSerialized]特性对XML序列化无效!所以使用XML序列化时不需要对对象增加[Serializable]特性。
5.XML序列化对象详解
(1)说明
本节主要介绍:使用特性控制对象序列化成XML文件的格式。
(2)使用XmlElement(默认值)
类声明:

代码如下:

public class Person
    {
        [XmlElement]
        public string Name;//使用[XmlElement]特性
        public bool Sex;//默认使用了[XmlElement]特性
        public Person() { }//必须提供无参构造器,否则XmlSerializer将出错
    }

序列化生成的XML文件:

代码如下:

<Personxmlns:xsi="..."xmlns:xsd="...">
  <Name>李志伟</Name>
  <Sex>true</Sex>
</Person>

(3)使用XmlAttribute
类声明:


代码如下:

public class Person
    {
        [XmlElement]
        public string Name;
        [XmlAttribute]
        public bool Sex;
        public Person() { }//必须提供无参构造器,否则XmlSerializer将出错
    }

序列化生成的XML文件:

代码如下:

<Personxmlns:xsi="..."xmlns:xsd="..."Sex="true">
  <Name>李志伟</Name>
</Person>

(4)使用XmlText
类声明:

代码如下:

public class Person
    {
        [XmlText]
        public string Name;
        [XmlAttribute]
        public bool Sex;
        public Person() { }//必须提供无参构造器,否则XmlSerializer将出错
    }

序列化生成的XML文件:
<Personxmlns:xsi="..."xmlns:xsd="..."Sex="true">李志伟</Person>
(5)使用XmlType和XmlAttribute(重命名节点名称)
类声明:


代码如下:

[XmlType("个人信息")]
    public class Person
    {
        [XmlAttribute("姓名")]
        public string Name;
        [XmlAttribute("性别")]
        public bool Sex;
        public Person() { }//必须提供无参构造器,否则XmlSerializer将出错
    }

序列化生成的XML文件:
<个人信息xmlns:xsi="..."xmlns:xsd="..."姓名="李志伟"性别="true" />
(6)列表和数组的序列化
类声明:


代码如下:

[XmlType("个人信息")]
    public class Person
    {
        [XmlAttribute("姓名")]
        public string Name;
        [XmlAttribute("性别")]
        public bool Sex;
        public Person() { }//必须提供无参构造器,否则XmlSerializer将出错
    }
    class Program
    {
        static void Main(string[] args)
        {
            Person p = new Person();
            p.Name = "李志伟";
            p.Sex = true;
            Person[] ps = new Person[3];
            ps[0] = p;
            ps[1] = p;
            ps[2] = p;
            //使用XML序列化对象
            string fileName = @"D:\users\lizw\桌面\Programmers.xml";//文件名称与路径
            Stream fStream = new FileStream(fileName, FileMode.Create);
            XmlSerializer xmlFormat = new XmlSerializer(typeof(Person[]));
            xmlFormat.Serialize(fStream, ps);//序列化对象
            fStream.Dispose();//关闭文件
            Console.WriteLine("OK!");
            Console.Read();
        }
    }

序列化生成的XML文件:


代码如下:

<ArrayOf个人信息xmlns:xsi="..."xmlns:xsd="...">
  <个人信息姓名="李志伟"性别="true" />
  <个人信息姓名="李志伟"性别="true" />
  <个人信息姓名="李志伟"性别="true" />
</ArrayOf个人信息>

注意:发现此时的XML文件的根节点名称变了。此时要重命名根节点应使用如下方式:


代码如下:

[XmlType("个人信息")]
    public class Person
    {
        [XmlAttribute("姓名")]
        public string Name;
        [XmlAttribute("性别")]
        public bool Sex;
        public Person() { }//必须提供无参构造器,否则XmlSerializer将出错
    }
    [XmlType("人员信息")]
    public class PersonArray : List<Person> { }
    class Program
    {
        static void Main(string[] args)
        {
            Person p = new Person();
            p.Name = "李志伟";
            p.Sex = true;
            PersonArray ps = new PersonArray();
            ps.Add(p);
            ps.Add(p);
            ps.Add(p);
            //使用XML序列化对象
            string fileName = @"D:\users\lizw\桌面\Programmers.xml";//文件名称与路径
            Stream fStream = new FileStream(fileName, FileMode.Create);
            XmlSerializer xmlFormat = new XmlSerializer(typeof(PersonArray));
            xmlFormat.Serialize(fStream, ps);//序列化对象
            fStream.Dispose();//关闭文件
            Console.WriteLine("OK!");
            Console.Read();
        }
    }

序列化生成的XML文件:


代码如下:

<人员信息xmlns:xsi="..."xmlns:xsd="...">
  <个人信息姓名="李志伟"性别="true" />
  <个人信息姓名="李志伟"性别="true" />
  <个人信息姓名="李志伟"性别="true" />
</人员信息>

(7)列表和数组的做为数据成员的序列化
类声明:

代码如下:

[XmlType("信息")]
    public class Person
    {
        [XmlAttribute("姓名")]
        public string Name;
        [XmlAttribute("性别")]
        public bool Sex;
        public Person() { }//必须提供无参构造器,否则XmlSerializer将出错
    }
    public class PersonArray
    {
        public List<Person> Array=new List<Person>();
        public Person Person = new Person();
    }
    class Program
    {
        static void Main(string[] args)
        {
            PersonArray ps = new PersonArray();
            ps.Person = new Person();
            ps.Person.Name = "李志伟";
            ps.Person.Sex = true;
            ps.Array.Add(ps.Person);
            ps.Array.Add(ps.Person);
            ps.Array.Add(ps.Person);
            //使用XML序列化对象
            string fileName = @"D:\users\lizw\桌面\Programmers.xml";//文件名称与路径
            Stream fStream = new FileStream(fileName, FileMode.Create);
            XmlSerializer xmlFormat = new XmlSerializer(typeof(PersonArray));
            xmlFormat.Serialize(fStream, ps);//序列化对象
            fStream.Dispose();//关闭文件
            Console.WriteLine("OK!");
            Console.Read();
        }
    }

序列化生成的XML文件:

代码如下:

<PersonArrayxmlns:xsi="..."xmlns:xsd="...">
  <Array>
    <个人信息姓名="李志伟"性别="true" />
    <个人信息姓名="李志伟"性别="true" />
    <个人信息姓名="李志伟"性别="true" />
  </Array>
  <Person姓名="李志伟"性别="true" />
</PersonArray>

注意:假设这里需要为Array和Person的节点重命名,代码如下:

代码如下:

[XmlType("信息")]
    public class Person
    {
        [XmlAttribute("姓名")]
        public string Name;
        [XmlAttribute("性别")]
        public bool Sex;
        public Person() { }//必须提供无参构造器,否则XmlSerializer将出错
    }
    public class PersonArray
    {
        [XmlArrayItem("个人信息")]
        [XmlArray("人员信息")]
        public List<Person> Array=new List<Person>();
        public Person Person = new Person();
    }

序列化生成的XML文件:


代码如下:

<PersonArrayxmlns:xsi="..."xmlns:xsd="...">
  <人员信息>
    <个人信息姓名="李志伟"性别="true" />
    <个人信息姓名="李志伟"性别="true" />
    <个人信息姓名="李志伟"性别="true" />
  </人员信息>
  <Person姓名="李志伟"性别="true" />
</PersonArray>

注意:把“人员信息”节点去掉呢(直接出现“个人信息”节点)


代码如下:

[XmlType("信息")]
    public class Person
    {
        [XmlAttribute("姓名")]
        public string Name;
        [XmlAttribute("性别")]
        public bool Sex;
        public Person() { }//必须提供无参构造器,否则XmlSerializer将出错
    }
    public class PersonArray
    {
        [XmlElement("个人信息")]
        public List<Person> Array=new List<Person>();
        public Person Person = new Person();
    }

序列化生成的XML文件:


代码如下:

<PersonArrayxmlns:xsi="..."xmlns:xsd="...">
  <个人信息姓名="李志伟"性别="true" />
  <个人信息姓名="李志伟"性别="true" />
  <个人信息姓名="李志伟"性别="true" />
  <Person姓名="李志伟"性别="true" />
</PersonArray>

(8)类型继承与反序列化
类声明:


代码如下:

public class Base { }
    [XmlType("信息A")]
    public class PersonA : Base
    {
        [XmlAttribute("姓名")]
        public string Name;
        [XmlAttribute("性别")]
        public bool Sex;
        public PersonA() { }//必须提供无参构造器,否则XmlSerializer将出错
    }
    [XmlType("信息B")]
    public class PersonB : Base
    {
        [XmlElement("姓名")]
        public string Name;
        [XmlElement("年龄")]
        public int Age;
        public PersonB() { }//必须提供无参构造器,否则XmlSerializer将出错
    }
    [XmlType("人员信息")]
    public class PersonArray
    {
        [XmlArrayItem(typeof(PersonA)), XmlArrayItem(typeof(PersonB))]
        public List<Base> ListPerson=new List<Base>();
    }
    class Program
    {
        static void Main(string[] args)
        {
            PersonA pa = new PersonA();
            pa.Name = "李志伟A";
            pa.Sex = true;
            PersonB pb = new PersonB();
            pb.Name = "李志伟B";
            pb.Age = 21;
            PersonArray ps = new PersonArray();
            ps.ListPerson.Add(pa);
            ps.ListPerson.Add(pa);
            ps.ListPerson.Add(pb);
            ps.ListPerson.Add(pb);
            //使用XML序列化对象
            string fileName = @"D:\users\lizw\桌面\Programmers.xml";//文件名称与路径
            Stream fStream = new FileStream(fileName, FileMode.Create);
            XmlSerializer xmlFormat = new XmlSerializer(typeof(PersonArray));
            xmlFormat.Serialize(fStream, ps);//序列化对象
            fStream.Dispose();//关闭文件
            Console.WriteLine("OK!");
            Console.Read();
        }
    }

序列化生成的XML文件:


代码如下:

<人员信息xmlns:xsi="..."xmlns:xsd="...">
  <ListPerson>
    <信息A姓名="李志伟A"性别="true" />
    <信息A姓名="李志伟A"性别="true" />
    <信息B>
      <姓名>李志伟B</姓名>
      <年龄>21</年龄>
    </信息B>
    <信息B>
      <姓名>李志伟B</姓名>
      <年龄>21</年龄>
    </信息B>
  </ListPerson>
</人员信息>

注意:同时为列表成员指定多个[XmlArrayItem(typeof(XXX))]可实现多种派生类型混在一起输出。

(9)排除不需要序列化的成员
类声明:


代码如下:

public class Person
    {
        public string Name;
        [XmlIgnore]// 这个属性将不会参与序列化
        public bool Sex;
        public Person() { }
    }

序列化生成的XML文件:


代码如下:

<Personxmlns:xsi="..."xmlns:xsd="...">
  <Name>李志伟</Name>
</Person>

(10)强制指定成员的序列化顺序
类声明:


代码如下:

public class Person
{
[XmlElement(Order = 2)]
public string Name;
[XmlElement(Order = 1)]
public bool Sex;
public Person() { }//必须提供无参构造器,否则XmlSerializer将出错
}

序列化生成的XML文件:
<Personxmlns:xsi="..."xmlns:xsd="...">
  <Sex>true</Sex>
  <Name>李志伟</Name>
</Person>
(11)自定义序列化行为
类声明:


代码如下:

public class Person : IXmlSerializable
{
public string Name;
public bool Sex;
public Person() { }//必须提供无参构造器,否则XmlSerializer将出错
public System.Xml.Schema.XmlSchema GetSchema()
{
return null;
}
public void ReadXml(System.Xml.XmlReader reader)
{
Name = reader.GetAttribute("姓名");
Sex = reader.GetAttribute("性别").Equals("男") ? true : false;
}
public void WriteXml(System.Xml.XmlWriter writer)
{
writer.WriteAttributeString("姓名", Name);
writer.WriteAttributeString("性别", Sex ? "男" : "女");
}
}

序列化生成的XML文件:
<Person姓名="李志伟"性别="男" />
(12)序列化设置XML命名空间
类声明:


代码如下:

[XmlRoot(Namespace = "http://msdn.microsoft.com/vsdh.xsd")]
public class Person
{
public string Name;
public bool Sex;
public Person() { }
}

序列化生成的XML文件:


代码如下:

<Personxmlns:xsi="..."xmlns:xsd="..."xmlns="http://msdn.microsoft.com/vsdh.xsd">
  <Name>李志伟A</Name>
  <Sex>true</Sex>
</Person>

(13)XML的使用建议
在服务端,C#代码中:
1. 建议不用使用低级别的XML API来使用XML,除非你是在设计框架或者通用类库。
2. 建议使用序列化、反序列化的方法来生成或者读取XML
3. 当需要考虑使用XML时,先不要想着XML结构,先应该定义好数据类型。
4. 列表节点不要使用[XmlElement],它会让所有子节点【升级】,显得结构混乱。
5. 如果希望序列化的XML长度小一点,可以采用[XmlAttribute],或者指定一个更短小的别名。
6. 不要在一个列表中输出不同的数据类型,这样的XML结构的可读性不好。
7. 尽量使用UTF-8编码,不要使用GB2312编码。
在客户端,JavaScript代码中,我不建议使用XML,而是建议使用JSON来代替XML,因为:
1. XML文本的长度比JSON要长,会占用更多的网络传输时间(毕竟数据保存在服务端,所以传输是免不了的)。
2. 在JavaScritp中使用XML比较麻烦(还有浏览器的兼容问题),反而各种浏览器对JSON有非常好的支持。
(14)反序列化的使用总结
如果XML是由类型序列化得到那的,那么反序列化的调用代码是很简单的,反之,如果要面对一个没有类型的XML,就需要我们先设计一个(或者一些)类型出来,这是一个逆向推导的过程,请参考以下步骤:
1. 首先要分析整个XML结构,定义与之匹配的类型,
2. 如果XML结构有嵌套层次,则需要定义多个类型与之匹配,
3. 定义具体类型(一个层级下的XML结构)时,请参考以下表格。
6.自定义序列化(仅适用于二进制与SOAP)
(1)自定义序列化的实现方式
可以通过在对象上实现 ISerializable 接口来自定义序列化过程。这一功能在反序列化后成员变量的值失效时尤其有用,但是需要为变量提供值以重建对象的完整状态。要实现 ISerializable,需要实现 GetObjectData()方法以及一个特殊的构造函数,在反序列化对象时要用到此构造函数。
(2)示例程序


代码如下:

[Serializable]
public class Person : ISerializable
{
public string Name;
public bool Sex;
public Person() { }
//必须的够着方法,反序列化时调用
protected Person(SerializationInfo info, StreamingContext context)
{
Name = info.GetString("姓名");
Sex = info.GetBoolean("性别");
}
//序列化时调用
public void GetObjectData(SerializationInfo info, StreamingContext context)
{
info.AddValue("姓名", Name + "(自定义序列化)");
info.AddValue("性别", Sex);
}
public override string ToString()
{
return "姓名:" + this.Name + "\t性别:" + (this.Sex ? "男" : "女");
}
}
class Program
{
static void Main(string[] args)
{
Person p = new Person();
p.Name = "李志伟A";
p.Sex = true;
//使用二进制序列化对象
string fileName = @"D:\users\lizw\桌面\Programmers.xml";//文件名称与路径
Stream fStream = new FileStream(fileName, FileMode.Create);
BinaryFormatter binFormat = new BinaryFormatter();//创建二进制序列化器
binFormat.Serialize(fStream, p);//序列化对象
//使用二进制反序列化对象
fStream.Position = 0;//重置流位置
p = (Person)binFormat.Deserialize(fStream);//反序列化对象
Console.WriteLine(p);
fStream.Dispose();//关闭文件
Console.WriteLine("OK!");
Console.Read();}
}

注意:在序列化过程中调用 GetObjectData()时,需要填充方法调用中提供的 SerializationInfo对象。只需按名称/值对的形式添加将要序列化的变量。其名称可以是任何文本。只要已序列化的数据足以在反序列化过程中还原对象,便可以自由选择添加至 SerializationInfo 的成员变量。如果基对象实现了 ISerializable,则派生类应调用其基对象的 GetObjectData()方法。同样,在反序列化时也会调用含有(SerializationInfo info, StreamingContext context)参数的特殊的够着方法!否者将无法反序列化!!!

(0)

相关推荐

  • C#实现json的序列化和反序列化实例代码

    在做asp.net和unity进行http通信的时候,当unity客户端发出表单请求的时候,我要将他要请求的数据以json的格式返回给客户端,让客户端来解析.服务器端这一块就涉及到json的序列化和反序列化的问题. 两种方法都有例子,第一种是用泛型集合来存储的对象,然后将集合序列化一下:第二种是直接序列化的一个对象 复制代码 代码如下: using System;using System.Collections.Generic;using System.Web.Script.Serializat

  • 深入理解C#序列化与反序列化的详解

    在我们深入探讨C#序列化和反序列化之前我们先要明白什么是序列化,它又称串行化,是.NET运行时环境用来支持用户定义类型的流化的机制.序列化就是把一个对象保存到一个文件或数据库字段中去,反序列化就是在适当的时候把这个文件再转化成原来的对象使用.其目的是以某种存储形成使自定义对象持久化,或者将这种对象从一个地方传输到另一个地方..NET框架提供了两种串行化的方式:1.是使用BinaryFormatter进行串行化:2.使用SoapFormatter进行串行化:3.使用XmlSerializer进行串

  • C#中Serializable序列化实例详解

    本文实例讲述了C#中Serializable序列化.分享给大家供大家参考.具体分析如下: 概述: 序列化就是是将对象转换为容易传输的格式的过程,一般情况下转化打流文件,放入内存或者IO文件 中.例如,可以序列化一个对象,然后使用 HTTP 通过 Internet 在客户端和服务器之间传输该对象,或者和其它应用程序共享使用.反之,反序列化根据流重新构造对象. 一.几种序列化技术  1)二进制序列化保持类型保真度,这对于在应用程序的不同调用之间保留对象的状态很有用.例如,通过将对象序列化到剪贴板,可

  • c#数据的序列化和反序列化(推荐版)

    开始用的.net 自带的DataContractJsonSerializer进行序列化和反序列化,当代码写完以后,调试,我X(原谅我的脏话,因为确实让我生气),实体因为有[DataContractAttribute(IsReference=true )] 这样一个属性,提示不能序列化,当然手改一下啦,改完以后,提示基类EntityObject 的这个属性不可以 MY God!! 后来也是因为DataContractJsonSerializer 反序列化成集合的时候不好使,所以才下定决心废弃.采用

  • C#实现复杂XML的序列化与反序列化

    本文以一个实例的形式讲述了C#实现复杂XML的序列化与反序列化的方法.分享给大家供大家参考.具体方法如下: 已知.xml(再此命名default.xml)文件,请将其反序列化到一个实例对象. Default.XML文件如下: <?xml version="1.0" encoding="utf-8" ?> <config> <rules> <rule name="namea"> <params&

  • C#序列化与反序列化(Serialize,Deserialize)实例详解

    本文实例讲述了C#序列化与反序列化(Serialize,Deserialize)实现方法.分享给大家供大家参考.具体分析如下: 如果要保存运行程序过程的数据要么保存到数据库中,要么新建一个普通的文件,然后把数据保存进去.但是这两者有个缺点就是,不能把原有数据的结构也保存进去.比如一个类中的字段值保存进去后再读取出来必须再解析下才行.序列化技术让你省去了解析的过程.保存后再读取时直接得到一个class 序列化的方式有三种:BinaryFormatter,SoapFormatter,XmlSeria

  • C#中datatable序列化与反序列化实例分析

    本文实例讲述了C#中datatable序列化与反序列化,分享给大家供大家参考.具体方法如下: 一.datatable序列化 public string getSendDetailQuery(DateTime timeS, DateTime timeE, string sccount) { try { SmsOperate so = new SmsOperate(); //得到dt DataTable dtt = so.getSendDetailQuery(timeS, timeE, sccoun

  • C#中JavaScriptSerializer帮助类用法实例

    本文实例讲述了C#中JavaScriptSerializer帮助类用法.分享给大家供大家参考.具体如下: 关键代码如下: 复制代码 代码如下: using System; using System.Collections.Generic; using System.Text.RegularExpressions; using System.Web.Script.Serialization; namespace YanZhiwei.DotNet3._5.Utilities.Common {    

  • C#实现对象XML序列化的方法

    本文实例讲述了C#实现对象XML序列化的方法.分享给大家供大家参考.具体实现方法如下: 复制代码 代码如下: using system; using system.xml; using system.xml.serialization; using system.text; using system.io; public class util {     /// <summary>     /// 对象序列化成 xml string     /// </summary>     p

  • C# JavaScriptSerializer序列化时的时间处理详解

    最近被序列化困扰了一下下.原因看下面代码 class Program { static void Main(string[] args) { var user = new User { UserId = "sb", CreateDate = DateTime.Now }; var serialier = new JavaScriptSerializer(); var json = serialier.Serialize(user); Console.WriteLine(json); C

随机推荐