最近在做项目的过程中,遇到了比较两个内容为字符串List的需求,其内容为从数据库查出的数据与本地产生的数据进行对比,得出两者不同的元素,后来通过种种方式总结、优化出了一个比较简单的方法,不多说,直接贴代码:
private static List<String> getdifferentList(List<String> list1,List<String> list2){
Map<String, Integer> map=new HashMap<String, Integer>();
List<String> longList=list1;
List<String> shortList=list2;
if(list2.size()>list1.size()){
longList=list2;
shortList=list1;
}
for(String string:shortList){//将shortList放到map中,map的value任意数字即可
map.put(string,0);
}
shortList.clear();//清空shortList,用于存放longList中有map中没有的数据
Integer in;
for(String string:longList){
in=map.get(string);
if(null==in){
shortList.add(string);//longList中有map中没有的数据
}
}
return shortList;
}
此方法的流程就是先将长度短的list以值为Key放到map里,然后通过遍历长度长的list,依次调用get()方法,如果当前map中没有此key值,说明此元素为不重复元素,放到清理后的shortList里,执行完毕后返回出去。
需要注意两种细节问题,也是我当时遇到的:
1.注意两个参数list的String元素中是否含有空格,如有空格隐患最好用下trim()方法(当初数据库数据有空格,本地数据没有空格,总是得出两份数据,后来通过排查,得出是空格的问题)
2.根据需求来确定,如果其中一个list为空时,那么输出的将是另一个list的全部元素(避免其中一个list没有获取到值而传了进来)