@Test
public void mergeMapValuesTest() {
Map<Integer, ListContainer> map = Maps.newHashMap();
List<AClass> aClassList1 = Lists.newArrayList();
AClass aClass = new AClass(1, "zhuoli1", "haha1");
aClassList1.add(aClass);
aClassList1.add(new AClass(2, "zhuoli2", "haha2"));
aClassList1.add(new AClass(3, "zhuoli3", "haha3"));
List<AClass> aClassList2 = Lists.newArrayList();
aClassList2.add(aClass);
aClassList2.add(new AClass(5, "zhuoli5", "haha5"));
aClassList2.add(new AClass(6, "zhuoli6", "haha6"));
List<AClass> intersectResult = aClassList1.stream().filter(aClassList2::contains).collect(Collectors.toList());
System.out.println(intersectResult);
List<AClass> unionResult = Stream.of(aClassList1, aClassList2).flatMap(Collection::stream).distinct().collect(Collectors.toList());
assertEquals(unionResult.size(), 5);
System.out.println(unionResult);
List<AClass> differenceResult = aClassList1.stream().filter(x -> !aClassList2.contains(x)).collect(Collectors.toList());
System.out.println(differenceResult);
map.put(1, new ListContainer(aClassList1));
map.put(2, new ListContainer(aClassList2));
List<AClass> aClassListResult = map.values().stream().flatMap(listContainer -> listContainer.getLst().stream()).collect(Collectors.toList());
assertEquals(aClassListResult.size(), 6);
System.out.println(aClassListResult);
}
@Test
public void intersectByKeyTest() {
List<Data2> listOfData2 = new ArrayList<Data2>();
listOfData2.add(new Data2(10501, "JOE", "Type1"));
listOfData2.add(new Data2(10603, "SAL", "Type5"));
listOfData2.add(new Data2(40514, "PETER", "Type4"));
listOfData2.add(new Data2(59562, "JIM", "Type2"));
listOfData2.add(new Data2(29415, "BOB", "Type1"));
listOfData2.add(new Data2(61812, "JOE", "Type9"));
listOfData2.add(new Data2(98432, "JOE", "Type7"));
listOfData2.add(new Data2(62556, "JEFF", "Type1"));
listOfData2.add(new Data2(10599, "TOM", "Type4"));
List<Data1> listOfData1 = new ArrayList<Data1>();
listOfData1.add(new Data1(10501, "JOE", 3000000));
listOfData1.add(new Data1(10603, "SAL", 6225000));
listOfData1.add(new Data1(40514, "PETER", 2005000));
listOfData1.add(new Data1(59562, "JIM", 3000000));
listOfData1.add(new Data1(29415, "BOB", 3000000));
List<OutputData> result = listOfData1.stream()
.flatMap(x -> listOfData2.stream()
.filter(y -> x.getId() == y.getId())
.map(y -> new OutputData(y.getId(), x.getName(), y.getType(), x.getAmount())))
.collect(Collectors.toList());
System.out.println(result);
List<Data1> data1IntersectResult = listOfData1.stream().filter(data1 -> listOfData2.stream().map(Data2::getId).collect(Collectors.toList()).contains(data1.getId())).collect(Collectors.toList());
System.out.println(data1IntersectResult);
}
@Test
public void flatMapToIntTest() {
List<List<String>> listOfLists = Arrays.asList(
Arrays.asList("1", "2"),
Arrays.asList("5", "6"),
Arrays.asList("3", "4")
);
IntStream intStream =
listOfLists.stream()
.flatMapToInt(childList ->
childList.stream()
.mapToInt(Integer::new));
int sum = intStream.peek(System.out::println).sum();
System.out.println("sum: " + sum);
}
@Test
public void mapToLongTest(){
List<Integer> integerList = Lists.newArrayList(1, 2, 3, 4, 5);
List<Long> longList = integerList.stream().mapToLong(x -> x).boxed().collect(Collectors.toList());
System.out.println(longList);
List<Double> doubleList = longList.stream().mapToDouble(x -> x).boxed().collect(Collectors.toList());
System.out.println(doubleList);
}