您的位置 首页 java

java导出讲解以及效率对比(代码演示)

在之前我们知道处理xls的excel用的workbook是HSSFWorkbook,处理xlsx的excel用的是XSSFWorkbook。

1、SXSSFWorkbook是在POI3.8版本开始提供基于XSSF低内存占用的SXSSF

SXSSF通过一个滑动窗口来限制访问Row的数量从而达到低内存占用的目录,XSSF可以访问所有行。SXSSF通过设置rowAccessWindowSize的大小实现滑动窗口中存储数据量的row数量,当行数超过滑动窗口设定的值时,此时旧的数据不再出现在滑动窗口且不可对此进行

访问,同时将此数据写入磁盘。也可通过flushRow(int keepRows)设定行数通过周期性的调用来修改。

注意:针对 SXSSF Beta 3.8下,会有临时文件产生,比如:

poi-sxssf-sheet4654655121378979321.xml

文件位置:java.io.tmpdir这个环境变量下的位置

Windows 7下是C:UsersxxxxxAppDataLocalTemp

Linux下是 /var/tmp/

2、当数据量超出65536条后,在使用HSSFWorkbook或XSSFWorkbook,程序会报OutOfMemoryError:Javaheap space;内存溢出错误。这时应该用SXSSFworkbook

3.SXFFSWoorkbook导出的excel相比于XSSFWoorkbook导出的更节省空间:

java导出讲解以及效率对比(代码演示)

4.测试HSSFXSSF导出的数据占用内存,而SXFFS导出的数据不容易造成内存溢出,数据改为5万条并且写入之后查看内存信息:

java导出讲解以及效率对比(代码演示)

将上面XSSF改为SXFFS查看结果:

java导出讲解以及效率对比(代码演示)

创作不易,如果这篇文章对你有用,请点个赞谢谢♪(・ω・)ノ!

文章来源:智云一二三科技

文章标题:java导出讲解以及效率对比(代码演示)

文章地址:https://www.zhihuclub.com/174419.shtml

关于作者: 智云科技

热门文章

网站地图