- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我的任务是改进一段生成大量报告的代码,以我认为合适的任何方式。
生成了大约 10 个相同的报告(针对数据库的每个“部分”),它们的代码类似于:
GeneratePurchaseReport(Country.France, ProductType.Chair);
GC.Collect();
GeneratePurchaseReport(Country.France, ProductType.Table);
GC.Collect();
GeneratePurchaseReport(Country.Italy, ProductType.Chair);
GC.Collect();
GeneratePurchaseReport(Country.Italy, ProductType.Table);
GC.Collect();
如果我删除那些 GC.Collect()
调用时,报告服务崩溃并显示 OutOfMemoryException
.
大部分内存保存在一个巨大的 List<T>
中。里面是GeneratePurchaseReport
并且一旦退出就不再使用 - 这就是完整的 GC 收集将回收内存的原因。
我的问题有两个:
GeneratePurchaseReport
上耗尽内存它应该在崩溃和燃烧之前进行完整的收集,不是吗?最佳答案
阅读大对象堆。
我认为正在发生的事情是随着时间的推移构建并附加各个报告的最终文档,这样在每次附加操作时都会创建一个新文档并丢弃旧文档(这可能在幕后发生)。该文档(最终)大于大型对象堆上存储的 85,000 字节阈值。
在这种情况下,您实际上并没有使用那么多物理内存——它仍然可用于其他进程。您正在使用的是您的程序可用的地址空间。 Windows 中的每个进程都有自己的(通常)2GB 可用地址空间。随着时间的推移,当您分配不断增长的报告文档的新副本时,在收集之前的副本时,您会在 LOH 中留下许多漏洞。先前对象释放的内存实际上不再使用,可供其他进程使用,但地址空间仍然丢失;它是零散的,需要压缩。最终这个地址空间被填满,你会得到一个 OutOfMemory 异常。
有证据表明调用 GC.Collect() 允许对 LOH 进行一些压缩,但这并不是一个完美的解决方案。几乎我在该主题上阅读的所有其他内容都表明 GC.Collect() 根本不应该压缩 LOH,但我已经看到了一些轶事报告(一些在 Stack Overflow 上),其中调用 GC.Collect()实际上能够避免 LOH 碎片造成的 OutOfMemory 异常。
一个“更好”的解决方案(确保您永远不会耗尽内存——使用 GC.Collect() 压缩 LOH 是不可靠的)是将您的报告拆分为小于85000 字节,并在最后将它们全部写入单个缓冲区,或者使用在增长时不会丢弃您之前工作的数据结构。不幸的是,这可能是更多的代码。
这里一个相对简单的选择是为比您的最大报表更大的 MemoryStream 对象分配一个缓冲区,然后在您构建报表时写入 MemoryStream。这样你就永远不会留下碎片。如果这只是写入磁盘,您甚至可以直接使用 FileStream(可能通过 TextWriter,以便以后更改)。如果此选项解决了您的问题,我想在对此答案的评论中听到它。
关于.net - 生成报告时诊断 .NET OutOfMemoryException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6053036/
@After public void afterScenario() { if (ScenarioManager.getScenario().isFailed()) {
我已将 BIRT 报告集成到 Grails 中并设计了一份报告。我的 grails 应用程序中有一个名为 startPeriod (仅限月份和年份)的参数,我想将其传递给 BIRT。然后 BIRT 调
我有一些 Oracle 报告 (.rdf),正在考虑将其转换为 BIRT 报告。有没有办法将 .rdf 文件转换为 BIRT 报告设计文件? 最佳答案 完全自动化的解决方案可能是不可能的。您可以部分自
当 gcc 4.1(使用 gcov)下一行: p = 新类; 报告为 100% 分支覆盖率 为什么? 因为启用了异常处理!!! 为了解决此问题,请指定: -fno-exceptions 在 g++
真的有好 免费 BugZilla 报告工具?我发现 Web 界面上的默认搜索选项太有限了。我最大的问题是缺少 Order By 选项(一次只有 1 个字段,可供选择的字段集非常有限)。我已经做了一些谷
是否可以在 CFMX7 上运行 ColdFusion Report builder 生成的报告? 更明确地说,是否可以将 CF7 中的报告生成引擎更改为 CF8? 最佳答案 我猜这可能很难做到。我记得
根据Lucintel发布的新市场报告,智能家居市场的未来看起来很有吸引力,在家用安全、家电、娱乐、照明、HVAC、医疗保健和厨房应用中将带来许多机遇。 由于COVID-19导致的全球经济衰退,
PHPCodeSniffer 是否生成 HTML 报告? 如果不是呢?怎么办? 目前,我可以运行 PHPCodeSniffer,但它只生成 XML 文件并在终端中显示结果。 如何在 phpunit 中
我在一个包中添加了一个简单的测试。 按照手册中的建议,我尝试让 PHPUnit 加载配置: phpunit -c /app phpunit.xml 看起来像这样:
我有两个从 csv 文件加载的数据框。基本上来自不同的环境但格式/列相似,它们的行/值可能有所不同。我想找到差异并在新的数据框中创建它们。两个数据框也将具有相同的顺序。我有 100 个要比较的文件。提
我想看看是否有办法通过 javadoc 在我的 junit 报告中包含“描述性文本”。 JUnit 4 似乎不像 TestNG 那样支持 @Test 注释的“描述”属性。 到目前为止,我所研究的只有一
我正在使用操作、 Controller 、servlet struts 框架编写 Excel 报告。该报告非常拥挤,已经有大约 10 个单独的查询。由于报告发生变化,我需要再添加大约 10 个查询。有
在放弃 Syleam 的 openerp jasper 模块后,我在 Nan Tic 的 jasper_reports 模块上苦苦挣扎。 它一直给我一个错误: File "C:\Program Fil
我希望创建一个简单的日历。每天由编码器生成条目计数并以日历样式查看。如一月、二月等。或按月显示全年。 database have date_added and encoder columns 我在将它
我必须为报告创建 MySQL 查询。 我有一个表history,它记录产品订单的状态更改。我有订单生命周期(订单流程)的以下状态:新、已确认、正在处理、已发货、已交付、已取消、已退回。订单不一定遵循此
如何将多个查询合并为一个? 例如: //Successful Sales: SELECT username, count(*) as TotalSales, sum(point) as Points
MySQL 优化技术的新手。请找到下面的 mysqltuner.pl 报告,并建议我应该更改 my.cnf 中的哪些变量以优化性能。 还有一个问题- 我无法在我的 my.cnf 中找到一些变量,例如
我想知道,我想将我的 Swing Worker 的某种形式的进度报告回主线程,以便我的界面可以使用随着进度增加而变化的标签进行更新,例如 checking 1/6... checking 2/6...
我正在尝试在“报告”>“销售”下运行 Magento Paypal 结算报告,但每次我尝试运行该报告时,我都会收到消息“由于配置为空,无法获取任何内容” 我查看了“系统”>“配置”>“销售”>“付款方
我想要一个工具来帮助创建 sql 查询(对于非 IT 人员),例如 dbforge。 我希望我们的非 IT 人员(例如运营)创建他们自己的 sql 查询。 我的第二个目标是让他们能够按需执行这些查询。
我是一名优秀的程序员,十分优秀!