java - 正确使用 JRSwapFileVirtualizer?

标签 java jasper-reports export

我正在导出一个非常大的 jasper 报告(大约 20000 页)。为此,为了避免内存不足错误,正如不同网站所建议的那样,我正在使用 JRSwapFileVirtualize,如下所示:

virtualizer = new JRSwapFileVirtualizer(1000, new JRSwapFile(reportFilePath, 2048, 1024), true);
parameters.put(JRParameter.REPORT_VIRTUALIZER, virtualizer);
.
.
JasperPrint print = JasperFillManager.fillReport(report, parameters, list);
virtualizer.cleanup();

我的问题是:

1) 我已经将 maxSize 配置为 1000。是否可以生成 20000 页的报告?

2) 我在方法调用“fillReport”后立即清理虚拟器。是否正确,或者我需要在将报告导出到 XLS 后清理虚拟器?

3) 无论如何在导出报告后清理虚拟器对我有帮助吗?

4) 创建JasperPrint对象,逻辑写在服务器端。导出报表逻辑,是用java客户端写的。如果我应该清理虚拟器,在导出报告后,我该如何处理这种情况?因为在这种情况下,我需要在服务器端创建此虚拟器的静态对象(因为 JRSwapFileVirtualizer 不可序列化,所以我无法在服务器和客户端之间创建和传递它),然后在导出后再次调用服务器端方法进行清理虚拟器。我在想创建静态对象是有风险的,因为如果对服务器端逻辑进行多次调用,那么虚拟器静态对象将持有对最新调用创建的交换文件的引用,因此在清理后,以前的交换文件可能不会被删除.

我找到了关于这个主题的更多信息: 在 jasper 提供的用于使用虚拟器的示例中,他们仅在调用 common export 时清理虚拟器,该导出会导出不止一种类型的文件。当他们只导出单一类型的报告时,他们没有调用清理:

else if (TASK_CSV.equals(taskName))
{
    exportCSV(jasperPrint);
}       
else if (TASK_EXPORT.equals(taskName))
{
    exportPDF(jasperPrint);
    exportXML(jasperPrint, false);
    exportHTML(jasperPrint);
    exportCSV(jasperPrint);

    // manually cleaning up
    virtualizer.cleanup();
}

他们也没有在这个例子中提到 XLS 导出。我找到了另一个链接,该人遇到了同样的问题,但也没有提到解决方案:

http://www.jasperforge.org/plugins/espforum/view.php?group_id=102&forumid=103&topicid=95689

此链接还说我们可以改用 JRXlsxExporter。但是 JRXlsxExporter 只导出 excel 2007 格式,不导出 2003 格式。

我正在使用 JExcelApiExporter.exportReport() 将报告导出到 XLS,对于大量报告,它不起作用。 请帮我解决这个问题。 任何小提示或建议都是值得赞赏的。如果您需要更多信息,请告诉我。 谢谢。

最佳答案

1.对于你的第一个问题, 这实际上取决于您为报告生成应用程序提供的堆大小。尝试试错场景,你会得到准确的尺寸

第二个问题

2.根据您的第一个代码片段, 您正在填写报告并立即在虚拟器上应用清理。因此,即使您创建了报告,清理后您的交换文件也将被销毁,因为您的数据。 -- 您应该在虚拟器上应用清理,一旦您确认报告数据使用已完成。所以在这种情况下导出为特定格式后。

3.cleanup是立即销毁swap文件。 因此,如果您不打算在导出后重新使用报告,则最好进行清理。 注意:即使你没有明确清理它,垃圾收集器也会在处理 jasperPrint 时销毁它。

你的第 4 点对我来说很不清楚,你是说 jasperPrint 一直在服务器端创建....导出逻辑是在客户端编写的......导出逻辑如何在客户端不引用JasperPrint,服务器端....??1!!

关于java - 正确使用 JRSwapFileVirtualizer?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11764598/

相关文章:

导出 mysql 错误 1064 <42000> : You have an error in your sql syntax

java - 当您检查变量(调试时)时,Eclipse 会做什么

java - 使用 Scala 或 Java 进行 Base 64 编码

java - Eclipse 4 (Kepler) 的 TPTP 等价物

java - 来自数据库的 JasperReport .jasper 文件

java - 贾斯珀报告错误 : ORA-01555: snapshot too old: rollback segment number with name "" too small ORA-22924: snapshot too old

java - 将数据传递到子报表

ios - 如何在 Xcode 6.1.1 中导出我的 iOS 项目?

java - 如何在java中进行用户控制缓存驱逐/垃圾收集?

netbeans - 如何使用 Netbeans/Github 导出修订版之间修改/添加的文件?