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.youkuaiyun.com/detail/bb_huiyi/9700893

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值