我有一个包含60万条记录的DataSet.当我尝试将这些数据写入XML文件时,总是会出现OutOfMemoryException.
以下是我目前如何写入数据的方法.
最有效的内存存储方式是什么?
using (MemoryStream output = new MemoryStream())
{
WorkingDataset.WriteXml(output, XmlWriteMode.WriteSchema);
using (FileStream outputFile = File.Create(FilePath))
{
using (GZipStream compressedStream = new GZipStream(outputFile, CompressionMode.Compress))
{
compressedStream.Write(output.GetBuffer(), 0, (int)output.Length);
}
}
}
解决方法:
为什么要使用MemoryStream?只需将其直接写入磁盘即可:
using (var fileStream = File.Create(FilePath))
{
using (var zipStream = new GZipStream(outputFile, CompressionMode.Compress))
{
WorkingDataset.WriteXml(zipStream, XmlWriteMode.WriteSchema);
}
}