簡體   English   中英

C#XML反序列化-性能問題

[英]C# XML deserialization - performance issue

我必須在反序列化之前解析XML文檔。 重用已解析的結果(通過創建讀取器)是否有意義,還是沒有性能差異?

var root = XDocument.Parse(message).Root;
var type = mes3.Name.LocalName;
if (type == typeOf(SomeType))
{
    var reader = root.CreateReader();
    var serializer = new XmlSerializer(typeof(SomeType));
    var someType = serializer.Deserialize(reader);
}

最好通過創建讀取器來重用解析的結果,而不是直接使用字符串消息來反序列化,因為在反序列化期間不會再次解析字符串。

如果我們使用快速而骯臟的演示程序:

using System;
using System.Text;
using System.Xml.Serialization;
using System.IO;
using System.Xml.Linq;
using System.Diagnostics;

namespace Sample_04_03_2014_01
{
    public class Sample
    {
        public string Name { get; set; }
    }
    class Program
    {
        static void Main(string[] args)
        {
            Sample s = new Sample();
            s.Name = "Hello";
            var serializer = new XmlSerializer(typeof(Sample));
            var sb = new StringBuilder();
            using (var sw = new StringWriter(sb))
            {
                serializer.Serialize(sw, s);
            }
            string serialized = sb.ToString();
            Console.WriteLine(serialized);

            var root = XDocument.Parse(serialized).Root;
            Sample someType1 = null;
            Stopwatch stopWatch1 = new Stopwatch();
            stopWatch1.Start();
            for (int i = 0; i < 100000; i++)
            {
                var serializer1 = new XmlSerializer(typeof(Sample));
                using (var reader = root.CreateReader())
                {
                    someType1 = (Sample)serializer1.Deserialize(reader);
                }
            }
            stopWatch1.Stop();
            Console.WriteLine(someType1.Name);
            Console.WriteLine(stopWatch1.Elapsed);

            Sample someType2 = null;
            Stopwatch stopWatch2 = new Stopwatch();
            stopWatch2.Start();
            for (int i = 0; i < 100000; i++)
            {
                var serializer2 = new XmlSerializer(typeof(Sample));
                using (TextReader reader = new StringReader(serialized))
                {
                    someType2 = (Sample)serializer2.Deserialize(reader);
                }
            }
            stopWatch2.Stop();
            Console.WriteLine(someType2.Name);
            Console.WriteLine(stopWatch2.Elapsed);
        }
    }
}

那么對於第一種方法(CreateReader),我們可以獲得約30%的性能提升。

你好00:00:00.8825465你好00:00:01.2636450

您的代碼具有以下相同的性能:

using (TextReader reader = new StringReader(message))
{
  result = serializer.Deserialize(reader);
}

通過你有額外的對象.....

我用這個

using (FileStream xmlFile = new FileStream(filePath, FileMode.Open))
{
       resultclass = (resultclasstype)serializer.Deserialize(xmlFile);
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM