zoukankan      html  css  js  c++  java
  • Java之Lists.Partition使用与坑

      将list集合按指定长度进行切分,返回新的List<List<??>>集合,如下的:

      List<List<Integer>> lists=Lists.partition(numList,3);

    package test;
     
    import com.google.common.collect.Lists;
    import org.junit.Test;
    import java.util.List;
    
    public class testList {
     
        @Test
        public void  test(){
            List<Integer> numList = Lists.newArrayList(1, 2, 3, 4, 5, 6, 7, 8);
            List<List<Integer>> lists=Lists.partition(numList,3);
            System.out.println(lists);  //[[1, 2, 3], [4, 5, 6], [7, 8]]
        }
    }

    Lists.Partition 在项目中遇到的坑总结:

      项目中使用 Lists.Partition 批量处理数据,但是最近内存一直 OutOffMemory,GC无法回收。

      后来我们对使用过的集合手动 clear,没有测试直接就上线了。尴尬的是内存回收了,但是跑出来的数据出问题了。

      最后自己单元测试发现是 List<List<TreasureIntegrationVo>> resultPartition = Lists.partition(list, 500) 之后再对 list 进行 clear 操作,resultPartition也会被清空。

      回来谷歌才发现它最终会调用 list.subList。subList 执行结果是获取 ArrayList 的一部分,返回的是 ArrayList 的部分视图。

      对子集合的操作会反映到原集合, 对原集合的操作也会影响子集合。

  • 相关阅读:
    用.net开发wap
    MVC3 中使用 Ajax.ActionLink Ajax.BeginForm
    收藏一下这个微软MVP的老外博客
    第三篇:Django的路由系统
    第二篇:Django自定义登录功能
    第一篇:Django简介
    json和pickle序列化模块
    oracle 11gr2 rac修改VIP
    修改监听端口号
    删除磁盘组
  • 原文地址:https://www.cnblogs.com/liang1101/p/13636452.html
Copyright © 2011-2022 走看看