有符号与无符号数强转的可逆性

有符号与无符号数强转的可逆性

 1         static void TestTypeConvert()
 2         {//把一个有符号数转为无符号后再转回来值保持不变,以下以1字节为例
 3             //原理:计算机中符点数都是有符号的,不存在这种转变,只剩下整数,
 4             //真值:绝对值的二进制值,如-1的真值为 00000001
 5             //整数是以补码形式存放的,计算机规定了正数的补码是本身,负数的补码是:符号位不变,真值按位取反再加1
 6             //强制转换做的事就是把一个补码看成是有符号还是无符号
 7             //有符号数,在计算时:符号位不变,真值按位取反再加1。无符号数直接计算,举例如下:
 8             //1,-1 的真值为00000001,补码为 1 111 1111,强转时就是把补码值看作是一个无符数,因此它=255
 9             //,再次强转时把它看成有符号数,符号位不管,其余位按位取反加1后是1,因此再次转回了-1
10             //2,-2 的真值为00000010,补码为 1 111 1110,强转时把补码看作无符号数,因此它=254
11             //3,-128真值有点特殊,128的二进制码为1000 0000,第8位是符号位,舍弃,取后面的0,即-128的真值为0
12             //补码经按位取反加1后还是 1 000 0000,强转时看成无符号数即为128
13             sbyte sb = -128;
14             var b = (byte)(sb);
15             var sb1 = (sbyte)(b);
16         }

 

posted on 2017-11-21 11:30 时空观察者9号 阅读(...) 评论(...) 编辑 收藏

你可能感兴趣的:(有符号与无符号数强转的可逆性)