可以通过遍历两个string数组来实现。
代码如下:
package com.czp.test;
import java.util.ArrayList;
import java.util.List;
public class TestList {
public static void main(String[] args) {
List
List
for (int i = 0; i < 10000; i++) {
list1.add("test"+i);
list2.add("test"+i*2);
}
getDiffrent(list1,list2);
//输出:total times 2566454675
}
/**
* 获取两个List的不同元素
* @param list1
* @param list2
* @return
*/
private static List
long st = System.nanoTime();
List
for(String str:list1)
{
if(!list2.contains(str))
{
diff.add(str);
}
}
System.out.println("total times "+(System.nanoTime()-st));
return diff;
}
}
源代码截图:
扩展资料:
Java是一门面向对象编程语言,不仅吸收了C++语言的各种优点,还摒弃了C++里难以理解的多继承、指针等概念,因此Java语言具有功能强大和简单易用两个特征。Java语言作为静态面向对象编程语言的代表,极好地实现了面向对象理论,允许程序员以优雅的思维方式进行复杂的编程。
Java具有简单性、面向对象、分布式、健壮性、安全性、平台独立与可移植性、多线程、动态性等特点 。Java可以编写桌面应用程序、Web应用程序、分布式系统和嵌入式系统应用程序等 。
参考资料:百度百科-网页链接
//
class Test {
public static void getUncontain(Listlist1, List list2){
for(String str1 : list1){
if(!list2.contains(str1)){
// 打印出list2没有b,d
System.out.println("ArrayList2里没有的是==>" + str1);
}
}
for(String str2 : list2){
if(!list1.contains(str2)){
// 打印出list1没有f,g
System.out.println("ArrayList1里没有的是==>" + str2);
}
}
}
public static void main(String[] args){
// 这里放置的是list1,list2
// 调用方法
getUncontain(list1, list2);
}
}
可以先用TreeSet逐个保存,然后将Set同两个List分别对比,多出来的就是“没有的”。
最基本的思路,实际上就是求集合的差:
双层for循环,外层是遍历List1,内层遍历List2,假若List1的那个元素在搜索完整个List2之后仍然没找到,那么可以做记录,List2中没有这个元素。
同理可以找到List1中没有的元素。
list1.removeAll(list2) 这样list1里就只剩下 list2里没有的了。同样
list2.removeAll(list1) 这样list2里就剩下list1里没有的了。