MM们
这里是一个没有使用任何第三方库的简单实现。主要优势retainAll, removeAll和addAll这些方法不修改输入到方法的原始列表。public class Test {
public static void main(String... args) throws Exception {
List list1 = new ArrayList(Arrays.asList("A", "B", "C"));
List list2 = new ArrayList(Arrays.asList("B", "C", "D", "E", "F"));
System.out.println(new Test().intersection(list1, list2));
System.out.println(new Test().union(list1, list2));
}
public List union(List list1, List list2) {
Set set = new HashSet();
set.addAll(list1);
set.addAll(list2);
return new ArrayList(set);
}
public List intersection(List list1, List list2) {
List list = new ArrayList();
for (T t : list1) {
if(list2.contains(t)) {
list.add(t);
}
}
return list;
}}