Qua*_*ter 228
你可以使用SequenceEqual.这适用于任何IEnumerable<T>,而不仅仅是数组.
Joh*_*nan 60
在LINQ中使用SequenceEqual .
int[] arr1 = new int[] { 1,2,3};
int[] arr2 = new int[] { 3,2,1 };
Console.WriteLine(arr1.SequenceEqual(arr2)); // false
Console.WriteLine(arr1.Reverse().SequenceEqual(arr2)); // true
Run Code Online (Sandbox Code Playgroud)
des*_*sco 28
此外,对于数组(和元组),您可以使用.NET 4.0中的新接口:IStructuralComparable和IStructuralEquatable.使用它们不仅可以检查数组的相等性,还可以比较它们.
static class StructuralExtensions
{
public static bool StructuralEquals<T>(this T a, T b)
where T : IStructuralEquatable
{
return a.Equals(b, StructuralComparisons.StructuralEqualityComparer);
}
public static int StructuralCompare<T>(this T a, T b)
where T : IStructuralComparable
{
return a.CompareTo(b, StructuralComparisons.StructuralComparer);
}
}
{
var a = new[] { 1, 2, 3 };
var b = new[] { 1, 2, 3 };
Console.WriteLine(a.Equals(b)); // False
Console.WriteLine(a.StructuralEquals(b)); // True
}
{
var a = new[] { 1, 3, 3 };
var b = new[] { 1, 2, 3 };
Console.WriteLine(a.StructuralCompare(b)); // 1
}
Run Code Online (Sandbox Code Playgroud)
Yul*_*mok 17
对于.NET 4.0及更高版本,您可以使用StructuralComparisons类型比较数组或元组中的元素:
object[] a1 = { "string", 123, true };
object[] a2 = { "string", 123, true };
Console.WriteLine (a1 == a2); // False (because arrays is reference types)
Console.WriteLine (a1.Equals (a2)); // False (because arrays is reference types)
IStructuralEquatable se1 = a1;
//Next returns True
Console.WriteLine (se1.Equals (a2, StructuralComparisons.StructuralEqualityComparer));
Run Code Online (Sandbox Code Playgroud)
Joh*_*iou 12
SequenceEqual 只有满足两个条件才会返回true.
如果您只想检查它们是否包含相同的元素而不管它们的顺序如何,并且您的问题属于类型
values2是否包含values1中包含的所有值?
您可以使用LINQ扩展方法Enumerable.Except,然后检查结果是否有任何值.这是一个例子
int[] values1 = { 1, 2, 3, 4 };
int[] values2 = { 1, 2, 5 };
var result = values1.Except(values2);
if(result.Count()==0)
{
//They are the same
}
else
{
//They are different
}
Run Code Online (Sandbox Code Playgroud)
而且通过使用它,您也可以自动获得不同的项目.一石二鸟.
请记住,如果您执行这样的代码
var result = values2.Except(values1);
Run Code Online (Sandbox Code Playgroud)
你会得到不同的结果.
在我的情况下,我有一个数组的本地副本,并想检查是否已从原始数组中删除任何内容,所以我使用此方法.
如果您想妥善处理null输入,而忽略项目的顺序,请尝试以下解决方案:
static class Extensions
{
public static bool ItemsEqual<TSource>(this TSource[] array1, TSource[] array2)
{
if (array1 == null && array2 == null)
return true;
if (array1 == null || array2 == null)
return false;
return array1.Count() == array2.Count() && !array1.Except(array2).Any();
}
}
Run Code Online (Sandbox Code Playgroud)
测试代码如下:
class Program
{
static void Main(string[] args)
{
int[] a1 = new int[] { 1, 2, 3 };
int[] a2 = new int[] { 3, 2, 1 };
int[] a3 = new int[] { 1, 3 };
int[] a4 = null;
int[] a5 = null;
int[] a6 = new int[0];
Console.WriteLine(a1.ItemsEqual(a2)); // Output: True.
Console.WriteLine(a2.ItemsEqual(a3)); // Output: False.
Console.WriteLine(a4.ItemsEqual(a5)); // Output: True. No Exception.
Console.WriteLine(a4.ItemsEqual(a3)); // Output: False. No Exception.
Console.WriteLine(a5.ItemsEqual(a6)); // Output: False. No Exception.
}
}
Run Code Online (Sandbox Code Playgroud)
假设数组相等意味着两个数组在相同的索引处具有相同的元素,则存在SequenceEqual答案和IStructuralEquatable答案。
但两者都有缺点,在性能方面。
SequenceEqual当数组具有不同长度时,.Net Framework 中的实现不会快捷,因此它可能会完全枚举其中一个,比较其每个元素。
这就是说,根据 .Net 风格(如 .Net5),它可能是快捷方式,请参阅此评论。所以对于一个最新的.Net项目来说,SequenceEqual应该是一个不错的选择。
IStructuralEquatable不是通用的,可能会导致每个比较值装箱。此外,它使用起来并不是很简单,并且已经需要编写一些辅助方法来隐藏它。
从性能角度来看,使用以下内容可能会更好:
bool ArrayEquals<T>(T[] first, T[] second)
{
if (first == second)
return true;
if (first == null || second == null)
return false;
if (first.Length != second.Length)
return false;
for (var i = 0; i < first.Length; i++)
{
if (!first[i].Equals(second[i]))
return false;
}
return true;
}
Run Code Online (Sandbox Code Playgroud)
但当然,这也不是检查数组相等性的某种“神奇方法”。
所以目前,Arrays.equals().Net 中还没有真正与 Java 相当的东西。
对于某些应用程序可能会更好:
string.Join(",", arr1) == string.Join(",", arr2)
Run Code Online (Sandbox Code Playgroud)