- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
使用XSSFWorkbook
,当尝试生成超过250 万行。
此外,我还添加了 JVM 参数 -Xms1024M 和 -Xmx6144,但没有成功。
while (rs.next()) {
row = spreadsheet.createRow(rowID);
for (int column = 0; column < numberOfColumns; column++) {
value = (String) rs.getString(column + 1);
cell = row.createCell(column);
cell.setCellStyle(style);
spreadsheet.setColumnWidth(column, COLUMN_WIDTH);
formatedValue = Engine.formatInput(colNames.get(column),value);
if (formatedValue instanceof Calendar) {
cell.setCellStyle(dateCellStyle);
cell.setCellValue((Calendar) formatedValue);
} else {
if (formatedValue instanceof Double) {
cell.setCellValue((Double) formatedValue);
} else {
if (formatedValue instanceof Integer) {
cell.setCellValue((Integer) formatedValue);
} else {
if (formatedValue instanceof String) {
cell.setCellValue((String) formatedValue);
} else {
/*
* Unreachable.
*/
cell.setCellValue(value);
}
}
}
}
}
rowID++;
if (this.isMaxSpreadsheetRowsReached(rowID)) {
newSpreadSheet(rsmd, numberOfColumns, styleEntete);
rowID = 1;
}
}
异常发生在for循环内部。
一种解决方法是使用 SXSSFWorkbook
,但我仍然想使用 XSSFWorkbook
。
有解决办法吗?
最佳答案
您已经回答了自己的问题。您的源似乎是流式传输的(rs.next()),而生成的工作簿存储在内存中。电子表格对象中有很多内部对象引用,这显然会导致复杂的垃圾收集器开销。
为了避免这种情况,请使用 XSSFWorkbook (SXSSFWorkbook) 的流版本。
但回到你可能问这个问题/不想流式传输的原因:您可能希望将所有寄存器保留在内存中,以便可以更新 header 信息(打印寄存器总数、平均值等)。我担心这种操作不能无限扩展,您可以通过运行源代码两次来实现这一点(首先累积所有辅助信息,如平均值、最大值或最小值,然后打印内容),或者通过打印所有这些信息都位于辅助页面上,然后您可以使用“=”公式在第一页中引用该信息,因此看起来信息位于页面顶部。
关于java - 线程 "main"java.lang.OutOfMemoryError : GC overhead limit exceeded 中 POI 的异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51768967/
我有一个 Node.JS 自动化,它使用 Puppeteer 并在过程中加载一些 URL。我的代码非常基本,仅使用包文档中记录的非常基本的函数。 自动化计划每 15 分钟使用 crontab 运行一次
我尝试阅读 stackoveflow 上回答的一些问题并根据此更改 eclipse.ini: 现在,除了一个应用程序之外,每个应用程序都可以正常运行。它显示此消息: 无法执行 dex:超出 GC 开销
问题描述: Task A. Amount of subtractions You have an array a length n. There are m queries (li,ri), for
编辑:看起来问题是过度使用#includes 创建圈子。我确保只包括那些需要的,它解决了前两个错误。 但是,我仍然为 BUtton 和 Elevator 得到“指定的多个默认构造函数” 每个错误都有两
在CloudKit中,我尝试通过批处理来保存大量的记录。但是,我的应用程序因以下错误而崩溃: Error pushing local data: 这是我的代码: CKModifyRecordsOpe
我正在尝试使用以下代码将 BigQuery 数据集从 Google Cloud Platform 下载到 R 工作区以对其进行分析: library(bigrquery) library(DBI) l
在 Kubernetes 中 Kubernetes Health Check Probes ,如果 timeoutSeconds 超过 periodSeconds 会怎样?例如: initialDel
我们正在使用 youtube 数据 api v3,并且已经有一段时间没有任何问题了。最近,我们收到了这个 403 异常: The request cannot be completed because
我正在将一个项目从gradle版本3.3转换为4.10.1。该项目主要是使用自定义构建步骤构建的C++代码,而不是CMake(externalNativeBuild)或Android.mk(ndkBu
这是我为查找小于或等于给定编号的跳跃数而编写的代码。它显示错误“超出输出限制” int main() { int t; cin>>t; while(t--) { long long int n
我正在尝试使用 Google Translate REST API 并同时请求以下网址: http://ajax.googleapis.com/ajax/services/language/trans
大多数时候,作为 .Net 开发人员,我们可以自由地在高级抽象世界中玩耍,但有时现实会踢你的私密部分,并告诉你要找到一个真的理解。 我刚刚经历过其中一次。我认为将角落数据列为项目列表就足够了,以便您了
我编写了一个更新函数,但是多次执行将产生错误context deadline exceeded。 我的功能: func Update(link string, m bson.M) { conf
我在我的网络服务器上同时使用 mysql 和 asp.net。我还使用 sqlite 数据库以便能够在另一台设备上使用该数据库。我需要在两个数据库之间发送数据。这是一天需要做很多次的事情。这是我如何做
我在我的应用程序中使用 Google TextToSpeech 已经很长时间了,我的许多用户都在使用离线语音,所以我对使用的资源数量没有任何问题。但是在收到 GoogleTTS 的最新更新后,我所有的
我正在尝试从 MySQL 5.0.45 数据库中删除几行: delete from bundle_inclusions; 客户端工作了一段时间,然后返回错误: Lock wait timeout ex
我试图将一个 ~200G 的文件加载到具有 4 个数据节点的 MySQL 集群中,我的目标表的 DDL 是这样的: CREATE TABLE XXXXXX ( ID BIGINT AUTO
我有这个脚本: def number_of_occurences(c, message): position = message.find(c) if position == -1:
我正在尝试对我的应用程序进行单元测试,但大部分测试都失败了,原因是异步等待失败:超过 30 秒的超时时间,未满足预期:“Home Code”。 我不知道为什么会这样失败,但这是我下面的代码 class
我的 HTML 表单是这样的 但是,当我上传一个 3mb 的文件时,它给出错误: Problem: File exceeded max_file_size" 最佳答案 我最后检查过,MAX_FIL
我是一名优秀的程序员,十分优秀!