当前位置:  开发笔记 > 编程语言 > 正文

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

如何解决《比较Java中的两个基元数组?》经验,为你挑选了2个好方法。

我知道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;
}

Jon Skeet.. 36

将您的第一个比较更改为:

if (a == b)
    return true;

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

但是,对于更简单的替代方法 - 使用Arrays.equals对每种基本类型都有重载.(实现与你的实现非常相似,除了它将数组长度提升到循环之外.在.NET上可以是反优化,但我想JRE库实现者可能对JVM更好:)



1> Jon Skeet..:

将您的第一个比较更改为:

if (a == b)
    return true;

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

但是,对于更简单的替代方法 - 使用Arrays.equals对每种基本类型都有重载.(实现与你的实现非常相似,除了它将数组长度提升到循环之外.在.NET上可以是反优化,但我想JRE库实现者可能对JVM更好:)



2> unwind..:

我认为最有效的方法是使用Arrays类中的helper方法,因为它们可能更巧妙地实现.所以在这种情况下,请使用

Arrays.equals(a, b);

推荐阅读
家具销售_903
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有