我刚刚在C#/.NET中观察到了一个奇怪的现象。
我创建了这个最小的示例来演示:
if (new sbyte[5] is byte[])
{
throw new ApplicationException("Impossible!");
}
object o = new sbyte[5];
if (o is byte[])
{
throw new ApplicationException("Why???");
}
这将抛出“为什么??”,但不会抛出“不可能!”它适用于所有相同大小的整型数组。有人能给我解释一下吗?我很困惑。顺便说一下,我正在使用.NET 4。
附言:我知道使用o.GetType() == typeof(byte[])
可以得到预期的结果。
发布于 2012-09-25 22:48:05
下面是一个更简单的例子,它展示了同样的问题:
static void Main(string[] args)
{
bool a = ((object) new byte[0]) is sbyte[];
bool b = (new byte[0]) is sbyte[];
Console.WriteLine(a == b); // False
}
之所以会出现这种不一致,是因为C#编译器认为它在编译时知道(new byte[0]) is sbyte[]
的结果,所以只替换了false
。也许它真的应该取代true
,以便更符合CLR的行为。
据我所知,只有这个小小的优化是不一致的。只有当is
表达式的两端被静态类型化为元素类型为有符号或无符号整数或枚举的数组,并且这些整数的大小相同时,才会发生这种情况。
好消息是,虽然这可能看起来不一致,但当C#将false
替换为此类表达式时,它总是会发出警告-在实践中,我认为这可能比悄悄返回true
更有用。
https://stackoverflow.com/questions/11976969
复制相似问题