技巧一:
不管是定点小数、定点整数,编码总位数相同的情况下,补码的表数个数总比原码、反码多一个,原因在于,真值0对应的原码、反码有两个编码(对应负零和正零),而真值0的补码只有一个。这就造成了同等条件下,补码的表数范围跟其他两种不一样,例如,当总编码位数(包含符号位)为8时,补码的表数范围为:-27≤X≤27-1,而原码、反码的表数范围为:-27-1≤X≤27-1。因此,此时,27=128有补码,却没有原码、反码。作为一种特例,真值“-1”被纳入定点小数补码的表数范围中,即定点小数补码的表数范围为:-1≤X<1,而定点小数原码、反码的表数范围为::-1<X<1(不包含-1)。
技巧二:
不管是定点小数、定点整数,在求各种编码时,都可遵循以下原则:正数的原码、反码、补码的符号位均为0,原码、反码、补码数值位均为数值本身;负数的原码、反码、补码的符号位均为1,原码的数值位为数值本身,反码的数值位为数值本身(即原码数值位)各位取反,而补码的数值位是在反码数值位的基础加1,若数值最高位有进位则丢弃(不向符号位进位)。
例如,当编码总位数为8时有:
+127的原码、反码、补码都为:0 1111111。
-127的原码、反码、补码依次为:1 1111111、1 0000000、1 0000001。
+0、-0的原码分别为:0 0000000、1 0000000,均对应真值0。
由于“编码总位数为8”的限制,真值-128无法用原码、反码来表示,似乎不能用上述规则来求解补码,但实际上是可行的——只要不管它的最高位即可,操作办法如下:
将128化为二进制为:1 0000000,最高位为1,可以只对舍去最高位后剩余的7位进行处理即可,首先取反得:1111111,加1得:1 0000000,最高位有进位需丢弃,即得:0000000,加上符号位就得补码:1 0000000。
又如,当编码总位数为4时,真值X=+0.101的原码、反码、补码均为:0 101。
真值X=-0.101的原码、反码、补码依次为:1 101、1 010、1 011。
同理,特例,-1的补码为:1 000。
在定点小数中,小数点隐含在第一位编码和第二位编码之间。
来源:刘智成原创