我有一个非常奇怪的问题。我有返回大量 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);
}