无论类型如何,比较两个整数对象的相等性

时间:2016-01-26 06:48:46

标签: c# .net math boxing

我想知道如何将两个盒装整数(可以是有符号或无符号的)相互比较以获得相等。

例如,看看这个场景:

// case #1
object int1 = (int)50505;
object int2 = (int)50505;
bool success12 = int1.Equals(int2); // this is true. (pass)

// case #2
int int3 = (int)50505;
ushort int4 = (ushort)50505;
bool success34 = int3.Equals(int4); // this is also true. (pass)

// case #3
object int5 = (int)50505;
object int6 = (ushort)50505;
bool success56 = int5.Equals(int6); // this is false. (fail)

我对如何以这种方式可靠地比较盒装整数类型感到困惑。我不知道它们在运行时是什么,我不能将它们都转换为long,因为一个可能是ulong。我也不能将它们都转换为ulong因为一个可能是否定的。

我能想到的最好的想法就是试错,直到找到一个普通类型或者可以排除它们不相等,这不是一个理想的解决方案。

2 个答案:

答案 0 :(得分:36)

在案例2中,您实际上最终会调用int.Equals(int),因为ushort可以隐式转换为int。此重载解析在编译时执行。它在案例3中不可用,因为编译器只知道int5int6的类型为object,因此它调用object.Equals(object) ...并且它&# 39;如果两个对象的类型不同,object.Equals将自然返回false

可以使用动态类型在执行时执行相同类型的重载解析 - 但是如果你尝试过类似的话,你仍然会遇到问题:

dynamic x = 10;
dynamic y = (long) 10;
Console.WriteLine(x.Equals(y)); // False

此处没有处理long的重载,因此它会调用普通object.Equals

一种选择是将值转换为decimal

object x = (int) 10;
object y = (long) 10;
decimal xd = Convert.ToDecimal(x);
decimal yd = Convert.ToDecimal(y);
Console.WriteLine(xd == yd);

这也会处理ulonglong的比较。

我选择了decimal因为它可以准确地表示每个原始整数类型的每个值。

答案 1 :(得分:0)

整数是value类型。比较两个整数类型时,compiller会检查

对象是reference类型。比较两个对象时,compiller会检查引用

有趣的部分在这里:

 object int5 = (int)50505; 

Compiller执行boxing操作,将值类型包装到引用类型中,Equals将比较引用,而不是值。