android 比较两个list,比较两个List的内容是否相等
一、问题
现在有两个ArrayList列表,列表中的元素是String字符串。比较这两个列表中的内容相等(可以顺序不一致)。如:
List lsit1 = new ArrayList<>();
List lsit2 = new ArrayList<>();
list1.add("1");
list1.add("1");
list1.add("3");
list1.add("2");
list2.add("1");
list2.add("3");
list2.add("2");
list2.add("2");
先贴上最终解决的代码:
public booelan equalsList(List list1, List list2){
// null情况
if ( (list1 == null && list2 != null)
|| (list1 != null && list2 == null) ) {
return false;
}
// 大小比较
if (list1.size() != list2.size) {
return false;
}
String[] arr1 = list1.toArray(new String[]{});
String[] arr2 = list2.toArray(new String[]{});
Arrays.sort(arr1);
Arrays.sort(arr1);
return Arrays.equals(arr1,arr2);
}
二、解决过程
首先可以想到的是,先null情况和两个列表size的比较。
如果只有一个列表为空,那么肯定不相等;
如果两个列表的size不相等,那么这两个列表的内容必定不相等
// null情况
if (list1 == null) {
return list2 == null;
}
// 大小比较
if (list1.size() != list2.size) {
return false;
}
大小和Null的情况已经判断完了。现在的两个列表必定是两个不为空且大小相等的列表。也就是说,现在只要比较内容是否都相同(忽略顺序)就可以了。有人认为可以用contains 或者 containsAll来解决,如:
使用contains()
for (String str : list1) {
if (!list2.contains(str)) {
return false;
}
}
return true;
或者
使用containsAll()
if (lsit1.containsAll(list2) && list2.containsAll(list1)) {
return true;
}
return false;
但是使用这两者方法都是用问题的,因为ArrayList中的元素可重复的。所以如果list1中为{"1","1","3","2"},list2中为{"1","3","2","2"},这个时候上面两种办法结果都会为true,显示这两个列表是不相同的。因为containsAll()中还是调用了contains方法。
使用contains和containsAll更适合与去重后的列表进行比较。但是这里的比较是不去重且无序的,所以不能用这个办法。
说到无序,大概就可能知道该怎么解决了。既然是无序的,那就把这两个list的内容排序再逐个的进行比较不就可以了?所以,Arrys.sort(),Arrays,equals(),就排上了用场。
String[] arr1 = list1.toArray(new String[]{});
String[] arr2 = list2.toArray(new String[]{});
Arrays.sort(arr1);
Arrays.sort(arr1);
return Arrays.equals(arr1,arr2); //这里可以自己遍历,但是明显使用Arrays.equals()方法更加的方便。
三、注意事项
但是需要注意的是,使用Arrys.sort(),Arrays,equals(),List中存放的对象必须实现了Comparable接口并重写了compareTo()方法和equals()方法。因为Arrays.sort()和Arrays.equals()会调用类的compareTo方法和equals()方法。
上面的例子使用的是String类型,String类型中已经实现了Comparable接口并重写了compareTo()方法和equals()方法以及hashCode()方法。
如果List中存放的类没有实现comparable接口,在使用Arrays.sort()是会抛出异常 java.lang.ClassCastException: XXX cannot be cast to java.lang.Comparable。
如果只实现了Comparable接口并重写了compareTo()方法,但是没有重写equals()和hashCode()方法。会导致结果一直为false,以为他比较的是两个对象的地址。所以在使用list比较时最好使用String 这种已经实现了Comparable接口的并已经重写了compareTo()、equals()、hashCode()方法的类比较方便。
android 比较两个list,比较两个List的内容是否相等相关推荐
- Android Studio导入Eclipse项目的两种方法
Android Studio导入Eclipse项目有两种方法,一种是直接把Eclipse项目导入Android Studio,另一种是在Eclipse项目里面进行转换,然后再导入Android Stu ...
- android中的定时任务一般有两种机制,android 定时任务
使用timertask进行定时任务 首先创建TimerTask: class SynchroTimerTask extends TimerTask { @Override public void ru ...
- Android一个ListView列表之中插入两种不同的数据
http://www.cnblogs.com/roucheng/ Android一个ListView列表之中插入两种不同的数据 代码如下: public class ViewHolder{Button ...
- Android中用GridView实现九宫格的两种方法(转)
Android中用GridView实现九宫格的两种方法 http://blog.csdn.net/shakespeare001/article/details/7768455 1.传统办法:实现一个继 ...
- 修改android的wifi客户端名称的两种方法
修改android的wifi客户端名称的两种方法 手机连接到无线路由时,在dhcp的客户端列表里面是这样的名称"android-89425253e5de3a2",这就是安卓手机的系 ...
- android自动隐藏虚拟键,Android 隐藏底部虚拟键的两种方法
方法一 滑动屏幕 可重新显示出来 protected void hideBottomUIMenu() { //隐藏虚拟按键,并且全屏 if (Build.VERSION.SDK_INT > 1 ...
- Android手机获取IP地址的两种方法
Android手机获取IP地址的两种方法 本文章讲解了WIFI和GPRS两种情况下获取手机IP地址的方法 1.使用WIFI 1,首先设置用户权限 AndroidManifest.xml添加: < ...
- 关于Android系统隐藏导航栏的两种方法
关于Android系统隐藏导航栏的两种方法 在NXP的imx6q和全志的A40I上试过 1.frameworks/base/core/res/res/values/dimens.xml中修改 < ...
- 用spss做多组两两相关性分析_两独立样本T检验及如何利用SPSS实现其操作
上一篇文章我们讲解了有关单样本T检验的相关内容(如何使用SPSS进行单样本检验),其实论文中除了常用到的单样本T检验以外,还有另外一种T检验的方法也是经常用到的统计方法,也就是两独立样本T检验 说到T ...
- 小实验:用创建进程()打开计算器,然后关闭进程句柄。再用打开进程(进程ID),使用两次,得到两个进程句柄。实验目的:这两个进程句柄都能控制这个进程吗?通过该试验加深对句柄的理解!!...
小实验:用创建进程()打开计算器,然后关闭进程句柄.再用打开进程(进程ID),使用两次,得到两个进程句柄.实验目的:这两个进程句柄都能控制这个进程吗? .版本 2 .程序集 窗口程序集1 .子程序 _ ...
最新文章
- javax.validation.ParameterNameProvider
- linux内核杂记(2)-内核的同步与并发
- vhdl变量赋初值_5.5 C++自动变量
- ftp连接 java.net.ConnectException: Connection refused
- oracle11g导入错误,oracle 11g导入到10g引起的错误
- 异常检测之浅谈入侵检测
- Pandas知识点-排序操作
- PAT乙级(1020 月饼)
- 脚本方式添加全文索引
- KeyShot实例教程教你怎么模拟水面效果
- quartus-ModeliSm仿真教程
- 整理:周鸿祎谈如何写商业计划书
- 打印纸张尺寸换算_常用纸张的尺寸大小对照表
- Android 10.0 recovery prompt_and_wait 跳过弹窗 自动 WIPE_DATA(出厂设置)
- Voldemort启动失败案例一则
- 【释义详解】Software License (软件许可证)是什么?
- 如何配置EditPlus放大、缩小字体的快捷键
- Joomla 漏洞总结
- 【cocos2d-x入门实战】微信飞机大战之八:自定义敌机精灵
- Git Bash 默认界面配色分析
热门文章
- R语言sunburst图(sunburst plot)可视化实战:使用sunburstR包和ggplot2包进行可视化
- R语言dplyr包的mutate函数将列添加到dataframe中或者修改现有的数据列:使用na_if()函数将0值替换为NA值、负收入替换为NA值
- Python使用tkinter构建一个多元回归预测模型GUI界面(接受用户输入数据并给出模型推理结果)
- sklearn GBDT(梯度下降树)模型使用RandomSearchCV获取最优参数及可视化​​​​​​​
- java maven 读写pdf_java读取pdf内容
- 已知某班学生的英语成绩按学号(从1开始)从小到大的顺序排列在tab表中,要查的学生学号放在变量no中,查表结果放在变量english中。
- oracle之 手动创建 emp 表 与 dept 表
- STM32-USART接收程序
- opencv函数总结
- 虚拟私有云网络VPC