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 的部分視圖。

  對子集合的操作會反映到原集合, 對原集合的操作也會影響子集合。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM