【闲来看源码】分析一下`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 值情况。

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

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

相关推荐
陈序缘5 分钟前
Rust 力扣 - 198. 打家劫舍
开发语言·后端·算法·leetcode·rust
凭君语未可8 分钟前
豆包MarsCode算法题:三数之和问题
java·算法
kirito学长-Java14 分钟前
springboot/ssm考试系统Java学生在线考试系统web学习论坛源码
java·spring boot·学习
帅气的花泽类16 分钟前
error Unexpected ‘debugger‘ statement no-debugger
java·maven
yyycqupt17 分钟前
数据库连接池(二)
linux·数据库·c++·后端·单例模式
cooldream200932 分钟前
SpringMVC 执行流程详解
java·spring·springmvc
redemption_233 分钟前
SpringMVC-01-回顾MVC
java
techdashen35 分钟前
Go context.Context
开发语言·后端·golang
凡人的AI工具箱37 分钟前
40分钟学 Go 语言高并发:Select多路复用
开发语言·后端·架构·golang
redemption_238 分钟前
Spring-02-springmvc
java