java比较两个list是否相同equals的代码详解

比较两个list是否相同,一般我用数组自带的函数equals,如:

public int updateTemplateByVO(ContentTemplateVO contentTemplateVO) throws Exception {
    int flag = 0;
    if (null == contentTemplateVO) {
      return flag;
    }
    //比较新编辑的模板参数是否与原有的参数相同
    //新的参数数组
    List<String> stringList = getParamListFromTemplateContent(contentTemplateVO);
    //旧的参数数组
    List<TContentTemplateParam> tContentTemplateParamList = selectTemplateParamsByTemplateId(contentTemplateVO.getId());
    List<String> paramList = new ArrayList<String>();
     //将从表里获取的数组重新整理成包含相同类型的list数组
    for (TContentTemplateParam contentParam : tContentTemplateParamList) {
      paramList.add(contentParam.getParamName());
    }
     //比较两个list
    Boolean sameSortFlag = stringList.equals(paramList);
    String content = contentTemplateVO.getSmsMsgContent();
    StringBuilder stringBuilder = new StringBuilder(content);
    //参数有修改则重新排序
    if (!sameSortFlag) {
      String newContent = rightSortForContentParam(contentTemplateVO.getSmsMsgContent());
      contentTemplateVO.setSmsMsgContent(newContent);
    }
    contentTemplateVO.setUpdateTime(DateUtil.getNowAsDate());

    TContentTemplate tContentTemplate = ModelCopyUtil.copy(contentTemplateVO, TContentTemplate.class);
    flag = tContentTemplateMapper.updateByPrimaryKeySelective(tContentTemplate);
    if (flag == 1 && (!sameSortFlag)) {
      //先删除对应模板的参数配置
      deleteContentTemplateParam(contentTemplateVO);
      //重新配置模板参数
      addContentTemplateParam(contentTemplateVO);

    }
    return flag;
  }

内容扩展:

Java的俩个list之间比较,判断是否一致的方法

前文

我看了一篇博客,是关于判断俩个list的。看完之后我觉得可能并不是很好。

结合他的思路,我重新整理了一下代码。

同时也看了看String中的equals的实现。

import java.util.List;

public class ListUtil {
  /**
   * 使用时,务必保证每个对象中实现了equals()方法。
   * 如果是自己写的类,比如,Dog,Cat这些的,请重写Object中的equals方法!
   *
   * @param aList 左右顺序无所谓
   * @param bList 左右顺序无所谓
   * @return 尽可能避免相同的情况
   */
  public static boolean equals(List aList, List bList) {

    if (aList == bList)
      return true;

    if (aList.size() != bList.size())
      return false;

    int n = aList.size();
    int i = 0;
    while (n-- != 0) {
      if (!aList.get(i).equals(bList.get(i)))
        return false;
      i++;
    }

    return true;
  }
}

代码过程
首先判断俩个对象是否相同,如果相同,直接返回true。

接着判断俩个的长度是否相同,相同才有比较的意义。

依照size,对list进行遍历。这里是需要用到equals方法,所以在对自己写的一些实体类判断的时候,一定要记得实现覆写hashCode()和equals()方法!同时切记equals方法的传入参数为Object!否则会因为重载的原因,不调用你写的方法。

最后,这个代码算法复杂度为n。

以上就是本次介绍的全部相关知识点,感谢大家的学习和对我们的支持。

(0)

相关推荐

  • 如何基于Java实现对象List排序

    这篇文章主要介绍了如何基于Java实现对象List排序,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 按照对象中的某个属性,对对象List进行排序. 以初唐四杰的成绩排名为例,对诗人进行排序. Java实现如下: 1.诗人(Poet)类结构,定义如下: /** * Created by Miracle Luna on 2020/1/11 */ public class Poet { private String name; private Do

  • Java List分页功能实现代码实例

    这篇文章主要介绍了Java List分页功能实现代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 今天,工作上,由于业务的一些特殊性,需要拿到数据后在java代码中进行分页. 写了一个工具类,记录如下: import java.util.ArrayList; import java.util.List; import org.apache.commons.collections.CollectionUtils; /** * java内存分

  • 简述Java List去重五种方法

    前言 去重,对于很多场合必不可少.写此篇文章是因为在之前做某个画面中,我在数据库中进行 Distinct 和 Order By 去重,发现影响效率,故此在后台先做去重处理:所以记录此文,已做参考: Num1:使用java8新特性stream进行List去重 public static void main(String[] args) { List list = new ArrayList(); list.add(10); list.add(11); list.add(14); list.add(

  • java比较两个list是否相同equals的代码详解

    比较两个list是否相同,一般我用数组自带的函数equals,如: public int updateTemplateByVO(ContentTemplateVO contentTemplateVO) throws Exception { int flag = 0; if (null == contentTemplateVO) { return flag; } //比较新编辑的模板参数是否与原有的参数相同 //新的参数数组 List<String> stringList = getParamL

  • Java比较两个对象大小的三种方法详解

    目录 一. 为什么需要比较对象 二. 元素的比较 1. 基本类型的比较 2. 引用类型的比较 三. 对象比较的方法 1. equals方法比较 2. 基于Comparable接口的比较 3. 基于Comparator接口的比较 4. 三种比较方式对比 一. 为什么需要比较对象 上一节介绍了优先级队列,在优先级队列中插入的元素必须能比较大小,如果不能比较大小,如插入两个学生类型的元素,会报ClassCastException异常 示例: class Student{ String name; in

  • Java合并两个及以上有序链表的示例详解

    目录 题目一:合并两个有序链表 题目一思路 题目一完整代码 题目二:合并多个有序链表 题目二关键思路 题目二完整代码 题目一:合并两个有序链表 题目链接 题目一思路 设置两个指针,一个指针(t1)指向l1链表头,另外一个指针(t2)指向l2链表头. 首先判断l1和l2的第一个元素,谁小,谁就是最后要返回的链表的头节点,如果l1和l2的第一个元素相等,随便取哪个都可以. 这样,我们就设置好了要返回链表的头节点,假设头节点是head, 依次移动t1和t2指针,谁小,谁就接入进来.依次操作,直到两个链

  • java编程实现并查集的路径压缩代码详解

    首先看两张路径压缩的图片: 并查集(Union-find Sets)是一种非常精巧而实用的数据结构,它主要用于处理一些不相交集合的合并问题.一些常见的用途有求连通子图.求最小生成树的 Kruskal 算法和求最近公共祖先(Least Common Ancestors, LCA)等. 使用并查集时,首先会存在一组不相交的动态集合 S={S 1 ,S 2 ,⋯,S k } ,一般都会使用一个整数表示集合中的一个元素. 每个集合可能包含一个或多个元素,并选出集合中的某个元素作为代表.每个集合中具体包含

  • java编程无向图结构的存储及DFS操作代码详解

    图的概念 图是算法中是树的拓展,树是从上向下的数据结构,结点都有一个父结点(根结点除外),从上向下排列.而图没有了父子结点的概念,图中的结点都是平等关系,结果更加复杂. 无向图                                                       有向图 图G=(V,E),其中V代表顶点Vertex,E代表边edge,一条边就是一个定点对(u,v),其中(u,v)∈V. 这两天遇到一个关于图的算法,在网上找了很久没有找到java版的关于数据结构中图的存储及其

  • java使用Apache工具集实现ftp文件传输代码详解

    本文主要介绍如何使用Apache工具集commons-net提供的ftp工具实现向ftp服务器上传和下载文件. 一.准备 需要引用commons-net-3.5.jar包. 使用maven导入: <dependency> <groupId>commons-net</groupId> <artifactId>commons-net</artifactId> <version>3.5</version> </depend

  • java使用RSA与AES加密解密的实例代码详解

    首先了解下,什么是堆成加密,什么是非对称加密? 对称加密:加密与解密的密钥是相同的,加解密速度很快,比如AES 非对称加密:加密与解密的秘钥是不同的,速度较慢,比如RSA •先看代码(先会用在研究) 相关依赖: <dependency> <groupId>org.bouncycastle</groupId> <artifactId>bcprov-jdk15on</artifactId> <version>1.58</versio

  • JAVA错误类结果类和分页结果类代码详解

    这篇文章主要介绍了JAVA错误类结果类和分页结果类代码详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 代码如下 public interface ErrorCode { String getCode(); String getMsg(); /** * 公共错误码<br/> * 码段:10000~10099 * * */ public enum CommonError implements ErrorCode { SUCCESS("

  • java中的前++和后++的区别示例代码详解

    java中的前加加++和后加加++,有很多人搞的很晕,不太明白!今天我举几个例子说明下前++和后++的区别! 其实大家只要记住一句话就可以了,前++是先自加再使用而后++是先使用再自加! 前++和后++总结:其实大家只要记住一句话就可以了,前++是先自加再使用而后++是先使用再自加! 请大家看下面的例子就明白了! public class Test { public static void main(String[] args) { //测试,前加加和后加加 //前++和后++总结:其实大家只要

  • Java 添加Word目录的2种方法示例代码详解

    目录是一种能够快速.有效地帮助读者了解文档或书籍主要内容的方式.在Word中,插入目录首先需要设置相应段落的大纲级别,根据大纲级别来生成目录表.本文中生成目录分2种情况来进行: 1.文档没有设置大纲级别,生成目录前需要手动设置 2.文档已设置大纲级别,通过域代码生成目录 使用工具: •Free Spire.Doc for Java 2.0.0 (免费版) •IntelliJ IDEA 工具获取途径1:通过官网下载jar文件包,解压并导入jar文件到IDEA程序. 工具获取途径2:通过Maven仓

随机推荐