javaにおけるListのセグメント化動作の例


javaにおけるListのセグメント化動作の例
問題:Aシステムが大きなListを検索したと仮定して、現在BシステムはこのListを入手してレポートを導き出そうとしていますが、Bシステムの配置環境条件は限られています。メモリはこのような大きなListを収容できません。この時にListを切り分けて、もう一つの導き出す必要があります。
伝統的な方式によっては、煩雑かもしれません。リスト内のsubList方法を使って実現できます。コードは以下の通りです。

import java.util.ArrayList;
import java.util.List;

public class listTest {

  public static void main(String[] args) {
    List<String> list = new ArrayList<String>();
    list.add("aaa");//index_0
    list.add("bbb");//index_1
    list.add("ccc");//index_2
    list.add("ddd");//index_3
    list.add("eee");//index_4
    list.add("fff");//index_5
    list.add("ggg");//index_6

    int flag = 3;//      

    int size = list.size();
    int temp = size / flag + 1;
    boolean special = size % flag == 0;
    List<String> cutList = null;
    for (int i = 0; i < temp; i++) {
      if (i == temp - 1) {
        if (special) {
          break;
        }
        cutList = list.subList(flag * i, size);
      } else {
        cutList = list.subList(flag * i, flag * (i + 1));
      }
      System.out.println(" " + (i + 1) + " :" + cutList.toString());
    }
  }
}

テスト:
1、フラグ=1

 1 :[aaa]
 2 :[bbb]
 3 :[ccc]
 4 :[ddd]
 5 :[eee]
 6 :[fff]
 7 :[ggg]
2、フラグ=2

 1 :[aaa, bbb]
 2 :[ccc, ddd]
 3 :[eee, fff]
 4 :[ggg]
3、フラグ=10

 1 :[aaa, bbb, ccc, ddd, eee, fff, ggg]
疑問があれば、メッセージをお願いします。あるいは、当駅のコミュニティに行って討論してください。ありがとうございます。この文章を通じて皆さんに助けてほしいです。ありがとうございます。