一、问题

现在有两个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的内容是否相等相关推荐

  1. Android Studio导入Eclipse项目的两种方法

    Android Studio导入Eclipse项目有两种方法,一种是直接把Eclipse项目导入Android Studio,另一种是在Eclipse项目里面进行转换,然后再导入Android Stu ...

  2. android中的定时任务一般有两种机制,android 定时任务

    使用timertask进行定时任务 首先创建TimerTask: class SynchroTimerTask extends TimerTask { @Override public void ru ...

  3. Android一个ListView列表之中插入两种不同的数据

    http://www.cnblogs.com/roucheng/ Android一个ListView列表之中插入两种不同的数据 代码如下: public class ViewHolder{Button ...

  4. Android中用GridView实现九宫格的两种方法(转)

    Android中用GridView实现九宫格的两种方法 http://blog.csdn.net/shakespeare001/article/details/7768455 1.传统办法:实现一个继 ...

  5. 修改android的wifi客户端名称的两种方法

    修改android的wifi客户端名称的两种方法 手机连接到无线路由时,在dhcp的客户端列表里面是这样的名称"android-89425253e5de3a2",这就是安卓手机的系 ...

  6. android自动隐藏虚拟键,Android 隐藏底部虚拟键的两种方法

    方法一  滑动屏幕 可重新显示出来 protected void hideBottomUIMenu() { //隐藏虚拟按键,并且全屏 if (Build.VERSION.SDK_INT > 1 ...

  7. Android手机获取IP地址的两种方法

    Android手机获取IP地址的两种方法 本文章讲解了WIFI和GPRS两种情况下获取手机IP地址的方法 1.使用WIFI 1,首先设置用户权限 AndroidManifest.xml添加: < ...

  8. 关于Android系统隐藏导航栏的两种方法

    关于Android系统隐藏导航栏的两种方法 在NXP的imx6q和全志的A40I上试过 1.frameworks/base/core/res/res/values/dimens.xml中修改 < ...

  9. 用spss做多组两两相关性分析_两独立样本T检验及如何利用SPSS实现其操作

    上一篇文章我们讲解了有关单样本T检验的相关内容(如何使用SPSS进行单样本检验),其实论文中除了常用到的单样本T检验以外,还有另外一种T检验的方法也是经常用到的统计方法,也就是两独立样本T检验 说到T ...

  10. 小实验:用创建进程()打开计算器,然后关闭进程句柄。再用打开进程(进程ID),使用两次,得到两个进程句柄。实验目的:这两个进程句柄都能控制这个进程吗?通过该试验加深对句柄的理解!!...

    小实验:用创建进程()打开计算器,然后关闭进程句柄.再用打开进程(进程ID),使用两次,得到两个进程句柄.实验目的:这两个进程句柄都能控制这个进程吗? .版本 2 .程序集 窗口程序集1 .子程序 _ ...

最新文章

  1. javax.validation.ParameterNameProvider
  2. linux内核杂记(2)-内核的同步与并发
  3. vhdl变量赋初值_5.5 C++自动变量
  4. ftp连接 java.net.ConnectException: Connection refused
  5. oracle11g导入错误,oracle 11g导入到10g引起的错误
  6. 异常检测之浅谈入侵检测
  7. Pandas知识点-排序操作
  8. PAT乙级(1020 月饼)
  9. 脚本方式添加全文索引
  10. KeyShot实例教程教你怎么模拟水面效果
  11. quartus-ModeliSm仿真教程
  12. 整理:周鸿祎谈如何写商业计划书
  13. 打印纸张尺寸换算_常用纸张的尺寸大小对照表
  14. Android 10.0 recovery prompt_and_wait 跳过弹窗 自动 WIPE_DATA(出厂设置)
  15. Voldemort启动失败案例一则
  16. 【释义详解】Software License (软件许可证)是什么?
  17. 如何配置EditPlus放大、缩小字体的快捷键
  18. Joomla 漏洞总结
  19. 【cocos2d-x入门实战】微信飞机大战之八:自定义敌机精灵
  20. Git Bash 默认界面配色分析

热门文章

  1. R语言sunburst图(sunburst plot)可视化实战:使用sunburstR包和ggplot2包进行可视化
  2. R语言dplyr包的mutate函数将列添加到dataframe中或者修改现有的数据列:使用na_if()函数将0值替换为NA值、负收入替换为NA值
  3. Python使用tkinter构建一个多元回归预测模型GUI界面(接受用户输入数据并给出模型推理结果)
  4. sklearn GBDT(梯度下降树)模型使用RandomSearchCV获取最优参数及可视化​​​​​​​
  5. java maven 读写pdf_java读取pdf内容
  6. 已知某班学生的英语成绩按学号(从1开始)从小到大的顺序排列在tab表中,要查的学生学号放在变量no中,查表结果放在变量english中。
  7. oracle之 手动创建 emp 表 与 dept 表
  8. STM32-USART接收程序
  9. opencv函数总结
  10. 虚拟私有云网络VPC