0

我有一个非常奇怪的问题。我有返回大量 XML 的 SQL Server 数据库。在中间我有.Net C# 代码。在前面我有两个项目,一个是 WCF,另一个是控制台应用程序(仅用于测试)。

现在,当我运行代码以从 DB 获取 XML 并使用控制台应用程序对其进行反序列化时,它运行得非常快。但是当我通过 WCF 运行相同的代码时,反序列化 XML 需要很长时间。我敢肯定,DB 不是这里的瓶颈,但 Serializer 是。

我正在使用 XmlSerializer。我无法切换到 DataContractSerializer,因为我有很多 XML 属性要处理。

编辑:

这是静态类中的序列化代码:

public static T DeSerialize(String xml)
{
    T dto = default(T);

    try
    {
        XDocument parsedXML = XDocument.Parse(xml);

        XmlSerializer serializer = new XmlSerializer(typeof(T));

        serializer.UnknownAttribute += new XmlAttributeEventHandler(serializer_UnknownAttribute);
        serializer.UnknownElement += new XmlElementEventHandler(serializer_UnknownElement);
        serializer.UnknownNode += new XmlNodeEventHandler(serializer_UnknownNode);
        serializer.UnreferencedObject += new UnreferencedObjectEventHandler(serializer_UnreferencedObject);

        if (serializer.CanDeserialize(parsedXML.CreateReader()))
        {
                    **--This is where everything gets stuck--**
            dto = (T)serializer.Deserialize(parsedXML.CreateReader());
        }
    }

    catch (Exception ex)
    {
        throw;
    }

    return dto;
}

然后我只有一个经理,假设 WorkManager 使用以下代码:

Work work = Serialize<Work>.DeSerialize(xml); 

上面的语句是从控制台应用程序和 WCF 项目中调用的。

界面是:

[OperationContract]
[WebInvoke(
Method = "POST",
RequestFormat = WebMessageFormat.Xml, ResponseFormat = WebMessageFormat.Xml, BodyStyle = WebMessageBodyStyle.Bare,
UriTemplate = "Work")]
XElement Work(Stream contents);

实现是:

public XElement Work(Stream contents)
{
     String xml = new StreamReader(contents).ReadToEnd();

     WorkManager workManager = new WorkManager();
     workManager.Work(xml);
}
4

1 回答 1

0

一些提示:

  1. 摆脱那个 try/catch 块。它没有为你做任何事,因为你总是throw;
  2. 不要调用 CreateReader 两次,并使用一个using块:

    using (var reader = parsedXML.CreateReader()) {
        if (serializer.CanDeserialize(reader))
        {
                **--This is where everything gets stuck--**
            dto = (T)serializer.Deserialize(reader);
        }
    }
    
于 2013-07-18T01:34:55.110 回答