所以我一直在为一个项目编写一段旧代码。我已经设法针对 64 位使用对其进行了优化。但是只有1个问题。使用 XmlSerializer.Deserialize 时它会中断,因为输入文本/反序列化数据太大。(溢出/超过 2gb int 限制)。
我试图找到解决方法,但没有任何答案有帮助。
这是有问题的代码。
if (File.Exists(dir + "/" + fileName))
{
string XmlString = File.ReadAllText(dir + "/" + fileName, Encoding.UTF8);
BXML_LIST deserialized;
using (MemoryStream input = new MemoryStream(Encoding.UTF8.GetBytes(XmlString)))
{
using (XmlTextReader xmlTextReader = new XmlTextReader(input))
{
xmlTextReader.Normalization = false;
XmlSerializer xmlSerializer = new XmlSerializer(typeof(BXML_LIST));
deserialized = (BXML_LIST)xmlSerializer.Deserialize(xmlTextReader);
}
}
xml_list.Add(deserialized);
}
在这里提出了许多问题之后,我认为我可以使用一种方法来“拆分”xml文件(同时保持相同类型的BXML_LIST)然后反序列化它并完成:将它组合以匹配它的原始内容以避免出现溢出错误时反序列化整个文件。
问题是,我不知道如何实现这一点。任何帮助或指导都会很棒!
// 编辑 1:
我从另一个站点找到了一段代码,不知道它是否是组合拆分的 xml 文件的可靠方法:
var xml1 = XDocument.Load("file1.xml");
var xml2 = XDocument.Load("file2.xml");
//Combine and remove duplicates
var combinedUnique = xml1.Descendants("AllNodes")
.Union(xml2.Descendants("AllNodes"));
//Combine and keep duplicates
var combinedWithDups = xml1.Descendants("AllNodes")
.Concat(xml2.Descendants("AllNodes"));