poi的工具类发现的问题

最近帮朋友做了一个poi的工具类,开始的时候随便写了一套,朋友在网上也找了一套,在测试5W的数据的时候发现了一个问题。我这边的程序直接内存溢出,而朋友的那个5W的数据3秒多就下来了。然后我就在我的上面做了一个循环判断,一次写入1W的数据,这个时候就可以了,但是耗时5秒多,差了2秒,而且非常吃内存。

我的工具类调用的是这个方法(之前的代码删除了,也比较多,就不完全贴上来了,通过参数看问题吧),

public static <E> void createExcel(String fileName,String[] titleName,List<Object[]> list,OutputStream out)

文件名  标题的数组  一个集合的object数组  输出流  我所有的数据都需要从拷贝到这个list集合里面,然后按照顺序把这个list集合的数据写入这个输出流。

这种调用的方法简单,而且我们现在的项目就是这样做的。但是他在之前有一个拷贝的过程,内存上面会从源数据list拷贝到这个object数组的list,5W的数据直接把计算机的内存给占,造成内存溢出。所以使用for循环多次就可以解决这个问题,但是调用GC还是比较频繁。效率比较低下。

我就想避免这个问题的发生,我就把自己的代码进行修改,减少这一次没有必要的内存拷贝。写入流的数据就需要按照一定的规则来实现,因为需求不同,对写入的数据也不一样,但是因为做的是一个工具类,不可能每使用一次就重写一套来实现。之所以用object数组来接收数据,就是为了顺序遍历每一个数据。取数规则就需要又用户来自定义。


所以我使用了一个抽象的方法来实现这个过程。

List<Account> list = new ArrayList<>();
		for(int i =0;i<50000;i++){
			Account account = new Account();
			account.setName("lie"+i);
			account.setAge(i);
			account.setCreatDate(new Date());
			list.add(account);
		}
		ExcelUtil.createExcel("test", titleName, out,new ExcelCreateHandler<Account>(list) {
			@Override
			public void generatebody() {
				List<Account> list2 = getList();
				for (Account account : list2) {
					addCellValue(account.getName(),account.getAge(),account.getCreatDate());
				}
			}
			});

通过实现一个抽象类的一个方法,让使用者自己取添加需要使用的参数。用一个可变参数来进行接收这些数据。把list以参数的形式传递给handler,然后在里面遍历这个对象,因为匿名内部类如果要使用上面的方法需要用final修饰,final修饰他的生命周期会被延长,使用后我们需要尽快的清理掉他,所以就采用参数来接收List。然后实现方法一个方法就可以了。


写好一个工具需要考虑的东西确实不少,这块还有待学习,效率也许就是一点点积累出来的,以前根本就没有考虑过的细节,也许就是效率浪费的地方。避免一些没有必要的拷贝,排序和循环等操作,可以提升不少效率。

具体的代码稍后贴上链接方便下载。如果有什么问题,请告知,谢谢。

http://download.csdn.net/detail/bb_huiyi/9700893

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
POI(Poor Obfuscated Implementation)是一款用于操作Microsoft Office格式文件的Java API库。它的目标是提供一种简单、快速、可靠的方式来读取、创建和编辑这些类型的文件,包括Excel、Word和PowerPoint等。 POI库中的HSSFWorkbook类用于操作Excel文件。开发者可以使用该类在内存中创建一个Excel文件,并将数据填充到不同的工作表和单元格中。此外,HSSFWorkbook也可以打开现有的Excel文件,以便进行编辑和保存。 为了将POI带入Excel,我们可以使用POI提供的API来实现Excel文件的下载。首先,我们需要创建一个HSSFWorkbook对象,并设置工作表的名字。然后,可以利用HSSFWorkbook对象创建一个或多个工作表,并填充所需的数据。最后,我们将HSSFWorkbook写入OutputStream或将其保存到本地文件中。这样,使用我们编写的代码,用户就可以下载包含所需数据的Excel文件。 例如,假设我们要从数据库中获取一些用户信息,并将其导出到Excel文件中进行下载。我们可以使用POI库提供的API来实现这个需求。首先,我们连接数据库并查询所需的用户信息。然后,我们创建一个HSSFWorkbook对象并设置一个工作表名称,比如“用户信息”。接下来,我们使用结果集将用户信息逐行填充到工作表的不同单元格中。最后,我们将HSSFWorkbook写入到OutputStream中,并将其作为一个可下载的文件返回给用户。 总之,POI是一个非常实用的工具类,可以帮助我们在Java应用程序中操作Excel文件。无论是创建、读取还是编辑Excel,POI库都提供了简单且丰富的API来满足我们的需求。通过将POI带入Excel,我们可以方便地实现Excel文件的下载功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值