【闲来看源码】分析一下`ArrayUtils.contains()`这个方法的实现

【闲来看源码】分析一下ArrayUtils.contains()这个方法的实现

大家先来看源码

java 复制代码
    @PreAuthorize("@ss.hasPermi('system:user:remove')")
    @Log(title = "用户管理", businessType = BusinessType.DELETE)
    @DeleteMapping("/{userIds}")
    public AjaxResult remove(@PathVariable Long[] userIds)
    {
        if (ArrayUtils.contains(userIds, getUserId()))
        {
            return error("当前用户不能删除");
        }
        return toAjax(userService.deleteUserByIds(userIds));
    }

这是一段源码,很简单,大家一看就懂!闲来无事看源码,我就好奇ArrayUtils.contains(userIds, getUserId())这里是怎么实现的?

我有两个好奇的地方:

  1. 不会也是使用遍历对比的吧?
  2. 会不会有些高级的写法?

我很好奇,我们一起看看吧------

进入方法内部,是这个样子:

java 复制代码
    public static boolean contains(Object[] array, Object objectToFind) {
        return indexOf(array, objectToFind) != -1;
    }

看来这个方法是传入目标数组和目标对象,然后调用内部的indexOf()方法进行对比的,那就看看呗

我们再进入

java 复制代码
   public static int indexOf(Object[] array, Object objectToFind) {
        return indexOf(array, objectToFind, 0);
    }

可以看到哈,这个有对于indexOf()方法实现了重载,多加了一个参数,也就是最后这个参数,我们再进,看看加的参数是什么参数

java 复制代码
public static int indexOf(Object[] array, Object objectToFind, int startIndex) {
    if (array == null) {
        return -1;
    } else {
        if (startIndex < 0) {
            startIndex = 0;
        }

        int i;
        if (objectToFind == null) {
            for(i = startIndex; i < array.length; ++i) {
                if (array[i] == null) {
                    return i;
                }
            }
        } else {
            for(i = startIndex; i < array.length; ++i) {
                if (objectToFind.equals(array[i])) {
                    return i;
                }
            }
        }

        return -1;
    }
}

看来终于看到了庐山真面目,现在我们就对于这段代码进行一个彻彻底底的分析,其实也简单,我就是多说点:

这段代码是 indexOf 方法的另一种重载,用于查找对象数组中特定对象的索引。以下是对代码的分析:

  1. 方法签名:public static int indexOf(Object[] array, Object objectToFind, int startIndex)

    • 返回类型:int,表示要查找的对象在数组中的索引位置,如果未找到则返回 -1。
    • 参数:
      • array:要搜索的对象数组。
      • objectToFind:要查找的对象。
      • startIndex:搜索的起始索引位置。
  2. 首先,代码检查输入数组 array 是否为 null,如果是则返回 -1。

  3. 然后,检查起始索引 startIndex 是否小于 0,如果是则将其设置为 0。

  4. 接下来,使用循环从起始索引开始遍历数组。根据 objectToFind 是否为 null,分别执行不同的比较:

    • 如果 objectToFind 为 null,使用 == 运算符检查数组中的元素是否也为 null。
    • 如果 objectToFind 不为 null,使用 equals 方法检查数组中的元素是否与 objectToFind 相等。
  5. 如果找到匹配的元素,返回该元素的索引值。

  6. 如果整个数组都被遍历但未找到匹配的元素,返回 -1。

这个方法的设计使得它可以用于查找对象数组中的特定对象,提供了灵活性,同时处理了可能的 null 值情况。

好啦,一切尽在不言中,感谢大家观看,懂的都懂!

伟大的生命,不论以何种形式,将会在宇宙间永存。我们这个小小星球上的人类,也将继续繁衍和发展,直至遥远的未来。可是,生命对于我们来说又多么短暂。不论是谁,总有一天,都将会走向自己的终点。死亡,这是伟人和凡人共有的最后归宿。热情的诗人高唱生命的恋歌,而冷静的哲学家却说:死亡是自然法则的胜利...... 是的,如果一个人是按自然法则寿终正寝,就生命而言,死者没有什么遗憾,活着的人也不必过分地伤痛。------------路遥《平凡的世界》

相关推荐
已是上好佳6 分钟前
java实验4 反射机制
java·开发语言
小园子的小菜11 分钟前
Rockect基于Dledger的Broker主从同步原理
java·开发语言
鹿屿二向箔13 分钟前
【论文+源码】创建一个基于Spring Boot的体育场管理系统
java·spring boot·后端
漫无目的行走的月亮13 分钟前
Spring boot实现图片上传和下载
java·spring boot
Libby博仙27 分钟前
asp.net core Web Api中的数据绑定
java·前端·asp.net
小金的学习笔记33 分钟前
SpringBootWeb案例-2
java·服务器·springboot·web
杰九36 分钟前
【全栈】SprintBoot+vue3迷你商城(2)
java·数据库·spring boot·mysql
华年源码36 分钟前
基于springboot的课程作业管理系统(源码+数据库+文档)
java·数据库·毕业设计·源码·springboot
黄霑和金庸我都喜欢41 分钟前
桌面开发 的设计模式(Design Patterns)核心知识
开发语言·后端·golang
Q_19284999062 小时前
基于Spring Boot的便民医疗服务小程序
spring boot·后端·小程序