Fork me on GitHub

itext 落雨 out of membery Memory Optimization

Memory Optimization

 

If a document deals with a lot of data or large elements, such as images, it is not wise to build the sections entirely in memory and then add them to the document. If you take a look at the code above and run it with 1,000,000 rows, you will run into an OutOfMemoryError!  You can try this for yourself by downloading the source code linked above. This is where the LargeElement interface that the PdfPTableChapter, and Sectionclasses implement, comes into play. Classes implementing the LargeElement interface can be added to the document before they are complete.This is achieved by setting the complete property to false.

 

void setComplete(boolean complete)

If you invoke setComplete(false), you indicate that the content of the object isn’t complete yet; it can be added to the document partially, but more will follow. If you invoke setComplete(true), you indicate that you won’t add any more data to the object.Once this is done, the element can be repeatedly added to the document, releasing memory that the added portion used. More information about the LargeElement interface can be found in the API Docs and this article with examples.Combining The TechniquesIt gets complex when you want to combine memory optimization and element grouping in scenarios that are not trivial.  The following code snippet modifies the previous example to show how to combine techniques.

复制代码
public static void memoryOptimizedElementGrouping(String filename, int rows)
  throws DocumentException, IOException {
    Document document = new Document(); // Create a document.
    PdfWriter.getInstance(document, new FileOutputStream(filename)); //Setup the writer
    document.open(); // Open the document
  
    PdfPTable mainTable = new PdfPTable(columns); // Main table of data
    mainTable.setComplete(false);
    PdfPTable alias = mainTable; //Alias to use for adding content.
    for (int i = 0; i < rows; ++i) {
        if (i == rows/2) {                    // Group at halfway point
            alias = new PdfPTable(columns); // Re-alias to new group table
            alias.setKeepTogether(true);
        }
        if (i == rows/2 + 5) {                // Add group 5 rows later.
            PdfPCell groupCell = new PdfPCell(alias); // Create the cell for group table
            groupCell.setColspan(columns); //Set it to span the entire mainTable
            mainTable.addCell(groupCell); //Add the group table to the main table
            alias = mainTable;
        }
        if (alias == mainTable && i % 10 == 0) {  // If no longer grouping
            document.add(mainTable);              // and i divisible by 10,
        }                                         // Add to the document
        alias.addCell(new Phrase("Left Cell "+i));
        alias.addCell(new Phrase("Right Cell "+i));
    }
  
    mainTable.setComplete(true);  //Set the table as complete
    document.add(mainTable);      //Add the mainTable to the document for last time.
    document.close();             //Close the document.
}
复制代码

First notice that the mainTable has its complete property set to false.  The main difference in the loop from the the last example is that the grouping happens in the middle of the table for five rows.  The memory optimization occurs in the third if block. The key point is to first check that alias is pointing to the mainTable. If you have not added your group to the mainTable and try adding the mainTable to the document, you will not get any new data from the group with subsequent additions of the mainTable. After the loop, the mainTable has its complete property to true, marking it as finished.  It can then be added to the document for a final time. If you run the source code, you can see that this second example can be run with 1,000,000 rows without causing an OutOfMemoryError.

 

转自:http://jandyco.com/advanced-itext/

 

另自己也有解决方案:

复制代码
//for循环中添加如下代码
int _MAX_ROWS = 1000;//最大行数,之后清理
int row_count = 0;//初始值
if (++row_count % _MAX_ROWS == 0) {
                           //datatable是我的一个PdfPTable的new出来的一个实例                          
                           // add table to Document
                           document.add(datatable);
                           // delete _MAX_ROWS from table to free memory
                           datatable.deleteBodyRows();
                           // let iText manage when table header written
                           datatable.setSkipFirstHeader(true);//防止释放后一页出现两次表头。
}
复制代码

详细参阅:

http://blog.csdn.net/ae6623/article/details/11590611

 

posted @   _落雨  阅读(416)  评论(0编辑  收藏  举报
编辑推荐:
· .NET制作智能桌面机器人:结合BotSharp智能体框架开发语音交互
· 软件产品开发中常见的10个问题及处理方法
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
· 一次Java后端服务间歇性响应慢的问题排查记录
阅读排行:
· 互联网不景气了那就玩玩嵌入式吧,用纯.NET开发并制作一个智能桌面机器人(四):结合BotSharp
· Vite CVE-2025-30208 安全漏洞
· 《HelloGitHub》第 108 期
· MQ 如何保证数据一致性?
· 一个基于 .NET 开源免费的异地组网和内网穿透工具
点击右上角即可分享
微信分享提示