我看了
a project的源代码,我注意到以下
statement(keyByte和codedByte都是类型字节):
return (byte)(keyByte - codedByte);
我现在想知道在keyByte小于codedByte的情况下会产生什么结果,这会导致一个负整数.
经过一些实验以了解一个值为[-255:-1]的值的负整数的结果,我得到以下结果:
byte result = (byte) (-6); // result = 250 byte result = (byte) (-50); // result = 206 byte result = (byte) (-17); // result = 239 byte result = (byte) (-20); // result = 236
因此,只要-256 < a< 0,我能够通过以下方式确定结果:
result = 256 + a;
我的问题是:我应该总是期望是这样吗?
解决方法
是的,这将永远是这种情况(即它不仅仅依赖于你的环境或编译器,而是被定义为C#语言规范的一部分).见
http://msdn.microsoft.com/en-us/library/aa691349(v=vs.71).aspx:
In an
unchecked
context,the result is truncated by discarding any high-order bits that do not fit in the destination type.
接下来的一个问题是,如果你把-256和-1之间的负数int的高阶位删掉,并把它读成一个字节,你会得到什么?这是你通过实验已经发现的:它是256 x.
请注意,字节顺序并不重要,因为我们丢弃高阶(或最高有效位),而不是“第一”24位.所以无论我们从哪一端接收,我们都留下了构成该int的最低有效字节.