javaにおけるListのセグメント化動作の例
javaにおけるListのセグメント化動作の例
問題:Aシステムが大きなListを検索したと仮定して、現在BシステムはこのListを入手してレポートを導き出そうとしていますが、Bシステムの配置環境条件は限られています。メモリはこのような大きなListを収容できません。この時にListを切り分けて、もう一つの導き出す必要があります。
伝統的な方式によっては、煩雑かもしれません。リスト内のsubList方法を使って実現できます。コードは以下の通りです。
1、フラグ=1
問題: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]
疑問があれば、メッセージをお願いします。あるいは、当駅のコミュニティに行って討論してください。ありがとうございます。この文章を通じて皆さんに助けてほしいです。ありがとうございます。