c# – ITextSharp合并多个pdf的内存不足异常

我必须将多个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可能会更大.

上一篇:PDF包含来自Java Itext的多个段落


下一篇:有没有办法从C#编写System.Drawing.Graphics到PDF?