接着上篇文章的分析的结果,在业务需求下这种循环内创建集合对象的使用,优化空间几乎没有了,因为循环内创建map对象,申请空间是避免不了的。所以没有必要将优化目标放到这了。 public static void outsideLoop...
接着上篇文章的分析的结果,在业务需求下这种循环内创建集合对象的使用,优化空间几乎没有了,因为循环内创建map对象,申请空间是避免不了的。所以没有必要将优化目标放到这了。
public static void outsideLoop() {
List<Map> list = new ArrayList<>();
int i = 0;
while (++i < 10000000){
Map<String,Object> map = new HashMap<>();
map.put("key0","values");
map.put("key1","values");
map.put("key2","values");
map.put("key3","values");
list.add(map);
}
// ------- 后续省略其他操作 ------
System.out.println("操作结束,完成数据量:"+list.size());
}
那这些场景的方法还能有哪些优化空间呢?
1、循环创建对象可以考虑clone
在循环内创建对象,还有种方案可以考虑clone的方式去申请空间,好处就是它通过克隆已有的对象属性(暂不细说深克隆、浅克隆),不需要调用构造方法,而new需要通过构造方法进行赋值。
但是并不是说clone的效率就一定比new的效率高,对于重量级的对象(属性多复杂)可以考虑使用clone的方式,这是相对于new的方式,其效率会更好一点,如果对应简单的对象new可能会更加快一点。因为两者都是需要申请对象空间的,所以内存上基本上没有什么差异,所以根据实际情况来选择使用。
2、方法内对象的合理使用,手动置null等待GC回收。
解释:在复杂的方法内部,可能存在很多对象的创建,但是因为方法未结束,导致这些对象生命周期未结束所以迟迟不能被GC,而占用内存空间,举例:上述代码种如果list集合在完成业务之后,可能后续还有其他很多操作,且使用不到list,此时就可以手动的去置空list对象,等待GC回收
public static void outsideLoop() {
List<Map> list = new ArrayList<>();
int i = 0;
while (++i < 10000000){
Map<String,Object> map = new HashMap<>();
map.put("key0","values");
map.put("key1","values");
map.put("key2","values");
map.put("key3","values");
list.add(map);
}
System.out.println("操作结束,完成数据量:"+list.size());
list = null;
// ------- 后续省略其他操作 ------
}
3、对于集合对象的创建,可以预先设置集合大小,尽量减少集合在使用过程中频繁执行扩容操作。
可以根据集合的扩容机制去初始化集合的容量,减少扩容过程,来达到提高执行效率的目的,当然了并不是盲目的初始化都可以提高效率的,简单说下因为初始化大容量后会申请空间,如果循环创建的对象大时,毫无疑问会增大GC的频率和时间,这时反而效率会降低。
本站主要用于日常笔记的记录和生活日志。本站不保证所有内容信息可靠!(大多数文章属于搬运!)如有版权问题,请联系我立即删除:“abcdsjx@126.com”。
QQ: 1164453243
邮箱: abcdsjx@126.com