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

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

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

相关推荐
无名指的等待71222 分钟前
SpringBoot中使用ElasticSearch
java·spring boot·后端
Tatakai2542 分钟前
Mybatis Plus分页查询返回total为0问题
java·spring·bug·mybatis
武子康1 小时前
大数据-133 - ClickHouse 基础概述 全面了解
java·大数据·分布式·clickhouse·flink·spark
.生产的驴1 小时前
SpringBoot 消息队列RabbitMQ 消费者确认机制 失败重试机制
java·spring boot·分布式·后端·rabbitmq·java-rabbitmq
Code哈哈笑1 小时前
【C++ 学习】多态的基础和原理(10)
java·c++·学习
chushiyunen1 小时前
redisController工具类
java
A_cot1 小时前
Redis 的三个并发问题及解决方案(面试题)
java·开发语言·数据库·redis·mybatis
刘某某.1 小时前
使用OpenFeign在不同微服务之间传递用户信息时失败
java·微服务·架构
alden_ygq1 小时前
GCP容器镜像仓库使用
java·开发语言
七折困2 小时前
列表、数组排序总结:Collections.sort()、list.sort()、list.stream().sorted()、Arrays.sort()
java·集合·数组·排序