我必须将多个1页pdf合并为一个pdf.我正在使用iTextSHarp 5.5.5.0来实现这一目标,但是当我合并超过900-1000 pdf时,我得到一个内存不足异常.我注意到,即使我释放我的阅读器并关闭它,内存永远不会被正确清理(进程使用的内存量永远不会减少)所以我想知道我可能做错了什么.这是我的代码:
using (MemoryStream msOutput = new MemoryStream())
{
Document doc = new Document();
PdfSmartCopy pCopy = new PdfSmartCopy(doc, msOutput);
doc.Open();
foreach (Tuple<string, int> file in filesList)
{
PdfReader pdfFile = new PdfReader(file.Item1);
for (int j = 0; j < file.Item2; j++)
for (int i = 1; i < pdfFile.NumberOfPages + 1; i++)//in this case it's always 1.
pCopy.AddPage(pCopy.GetImportedPage(pdfFile, i));
pCopy.FreeReader(pdfFile);
pdfFile.Close();
File.Delete(file.Item1);
}
pCopy.Close();
doc.Close();
byte[] content = msOutput.ToArray();
using (FileStream fs = File.Create(Out))
{
fs.Write(content, 0, content.Length);
}
}
它永远不会写入文件,我在p.Copy()期间得到一个内存不足异常.AddPage()部分.我甚至尝试刷新pCopy变量,但没有改变任何东西.我查看了iText的文档以及围绕*的各种问题,但在我看来,我正在采取一切建议来保持较低的内存使用率,但这种情况并没有发生.
有什么想法吗?
解决方法:
由于这是大量的东西,我建议直接写入FileStream而不是MemoryStream.这可能是一个实际情况,其中内存异常可能实际上意味着“内存不足”.
此外,正如Bruno指出的那样,不幸的是,PdfSmartCopy的“智能”部分也是以内存为代价的.切换到PdfCopy应该会降低内存压力,尽管最终的PDF可能会更大.