zoukankan      html  css  js  c++  java
  • C#中的Json的序列化和反序列化

    Json是一种通用的数据格式,我们在数据交换的时候,经常会用到,下面介绍c#中的json序列化和反序列化,当然也可用在asp.net,silverlight,wpf中。我们在下面实例讲解如何进行Json的序列化和反序列化,本文介绍两种方案,.net 3.5原生Json操作和Json.net中的Json操作。

    首先,我们先建立一个测试对象,用来序列化和反序列化。

    public class Person

    {

        public int ID { get; set; }

        public string Name { get; set; }

        public int Age { get; set; }

        public DateTime BirthDay { get; set; }

    }

    第一种,利用.Net Framework 3.5中原生的Json操作类库,特点就是不需要导入第三方类库,比较方便,速度上一般,而且需要.Net Framework的支持,我们知道现在还有很多服务器没有升级到.Net Framework 3.5,就用不了这个了。

    首先导入下面类库,并加入下面代码

    System.ServiceModel

    System.ServiceModel.Web

    class Program

    {

        static void Main(string[] args)

        {

            //创建测试对象

            Person p = new Person();

            p.ID = 1;

            p.Name = "张三";

            p.Age = 20;

            p.BirthDay = DateTime.Now.AddYears(-20);

            //将对象转化成Json字符串

            DataContractJsonSerializer ds = new DataContractJsonSerializer(typeof(Person));

            using (MemoryStream ms = new MemoryStream())

            {

                ds.WriteObject(ms, p);

                string output = Encoding.UTF8.GetString(ms.ToArray());

                Console.WriteLine(output);

            }

        }

    }

    输出结果

    这个是.Net Framework 3.5原生的序列化方式,接着,我们介绍反序列化方式,还是同样的加入下面代码

    class Program

    {

        static void Main(string[] args)

        {

            //创建测试对象

            Person p = new Person();

            p.ID = 1;

            p.Name = "张三";

            p.Age = 20;

            p.BirthDay = DateTime.Now.AddYears(-20);

            //将对象转化成Json字符串

            string output = string.Empty;

            DataContractJsonSerializer ds = new DataContractJsonSerializer(typeof(Person));

            using (MemoryStream ms = new MemoryStream())

            {

                ds.WriteObject(ms, p);

                output = Encoding.UTF8.GetString(ms.ToArray());

            }

            //将Json字符串转化成对象

            DataContractJsonSerializer outDs = new DataContractJsonSerializer(typeof(Person));

            using (MemoryStream outMs = new MemoryStream(Encoding.UTF8.GetBytes(output)))

            {

                Person outPerson = outDs.ReadObject(outMs) as Person;

                Console.WriteLine("ID:" + outPerson.ID);

                Console.WriteLine("Name:" + outPerson.Name);

                Console.WriteLine("Age:" + outPerson.Age);

                Console.WriteLine("Birthday:" + outPerson.BirthDay);

            }

        }

    }

    输出结果

    我们从.Net Framework 3.5原生的Json序列化及反序列化方式中,可以看出,还是相当麻烦的。很多网友也会问如果是.Net Framework 2.0该怎么办呢?下面,我们介绍一个第三方的Json序列化和反序列化类库,来完成上面操作,这个类库是有.Net Framework 2.0的版本的哦,而且这个类库还可以支持xml的序列化和反序列化操作(本文不做讲解)。下面看操作。

    class Program

    {

        static void Main(string[] args)

        {

            //创建测试对象

            Person p = new Person();

            p.ID = 1;

            p.Name = "张三";

            p.Age = 20;

            p.BirthDay = DateTime.Now.AddYears(-20);

            //将对象转化成Json字符串

            string output = JsonConvert.SerializeObject(p);

            Console.WriteLine(output);

        }

    }

    输出结果

    这个是Json序列化方法,是不是简单了很多呢?

    class Program

    {

        static void Main(string[] args)

        {

            //创建测试对象

            Person p = new Person();

            p.ID = 1;

            p.Name = "张三";

            p.Age = 20;

            p.BirthDay = DateTime.Now.AddYears(-20);

            //将对象转化成Json字符串

            string output = JsonConvert.SerializeObject(p);

            //将Json字符串转化成对象

            Person outPerson = JsonConvert.DeserializeObject<Person>(output);

            Console.WriteLine("ID:" + outPerson.ID);

            Console.WriteLine("Name:" + outPerson.Name);

            Console.WriteLine("Age:" + outPerson.Age);

            Console.WriteLine("Birthday:" + outPerson.BirthDay);

        }

    }

    输出结果

    这个是Json反序列化方法,简单吧,而且据说这个类库的速度比.Net原生的Json序列化和反序列化方法要快很多。下载地址http://json.codeplex.com/

    风雪七月花溅墨
  • 相关阅读:
    c++标准库容器【转】
    C++命名空间的解释 【转】
    [转载]定义、公理、定理、推论、命题和引理的区别
    待读论文
    矩阵分解 Matrix Factorization (RegularSVD) 实验总结
    Predicting the Next Location: A Recurrent Model with Spatial and Temporal Contexts AAAI2016
    Discovering Urban Functional Zones Using Latent Activity Trajectories TKDE 2015
    numpy
    python 编程 规范
    深度学习
  • 原文地址:https://www.cnblogs.com/bobo41/p/3392350.html
Copyright © 2011-2022 走看看