比较Java中的两个基元数组?

2022-09-02 05:29:24

我知道Arrays.deepEquals(Object[],Object[]),但这不适用于基元类型(由于数组和自动装箱的限制,请参阅此相关文章)。

考虑到这一点,这是最有效的方法吗?

boolean byteArrayEquals(byte[] a, byte[] b) {
    if (a == null && b == null)
        return true;

    if (a == null || b == null)
        return false;

    if (a.length != b.length)
        return false;

    for (int i = 0; i < a.length; i++) {
        if (a[i] != b[i])
            return false;
    }
    return true;
}

答案 1

将第一个比较更改为:

if (a == b)
    return true;

这不仅捕获了“两个空”情况,而且还捕获了“将数组与自身进行比较”的情况。

但是,对于更简单的替代方法 - 使用 Arrays.equals,它对每个基元类型都有重载。(该实现与您的实现非常相似,只是它将数组长度提升出循环。在.NET上,这可能是一个反优化,但我想JRE库实现者可能更了解JVM:)


答案 2

我认为最有效的应该是使用Arrays类中的帮助器方法,因为它们的实现可能更巧妙。因此,在这种情况下,请使用

Arrays.equals(a, b);