【发布时间】:2017-08-03 11:51:36
【问题描述】:
我一直在尝试使用各种方法将大型 PdfDocument 保存到字节数组中,但总是返回内存不足异常(文件为 200 MB 和 2.5K 页)。
我最初的尝试是简单地使用 MemoryStream
public static byte[] ProcessLargePdfDocument(PdfDocument pdfDocument)
{
using (MemoryStream stream = new MemoryStream())
{
pdfDocument.Save(stream, true);
return stream.ToArray();
}
}
然后我尝试添加一些缓冲
public static byte[] ProcessLargePdfDocument(PdfDocument pdfDocument, long whereToStartReading = 0)
{
List<byte> byteList = new List<byte>();
using (MemoryStream stream = new MemoryStream())
{
pdfDocument.Save(stream, false);
byte[] buffer = new byte[megabyte];
stream.Seek(whereToStartReading, SeekOrigin.Begin);
int bytesRead = stream.Read(buffer, 0, megabyte);
while (bytesRead > 0)
{
byteList.AddRange(buffer);
bytesRead = stream.Read(buffer, 0, megabyte);
}
}
return byteList.ToArray();
}
无论我尝试什么,我都会在 pdfDocument.Save 调用中遇到内存不足异常。我可以将其写入文件位置并使用 dev 中的缓冲 FileStream 将其读回,但由于权限(还),我无法在生产环境中执行此操作。
【问题讨论】:
标签: c# arrays pdf pdfsharp migradoc