目录
前言
学习完数的小数点表示,下一个需要解决的问题就是数的机器码表示问题。
在计算机中对数据进行运算操作时,符号位应该如何表示?是否也同数值位一道参加运算操作呢?如果参加,会给运算操作带来什么影响呢?为了妥善处理好这些问题,就产生了把符号位和数值位一起编码来表示相应的数的各种表示方法,如原码、补码、反码、移码。为了区别一般书写表示的数和机器中这些编码表示的数,通常将前者称为真值,后者称为机器数或机器码。
1.原码
表示:用机器数的最高位表示某个数的符号,其余的各位表示的绝对值。
示例:
注意:
若字长为n+1,则原码小数的表示范围为-(1-)≤x≤1-。
若字长为n+1,则原码整数的表示范围为-(-1)≤x≤-1。
真值零的原码表示有正零和负零两种形式。[+0]原 = 0000 / [-0]原 = 1000。
2.反码
表示:若为正数,则[x]反=[x]原。若为负数,则将该数原码的数值位全部取反。
示例:
注意:
若字长为n+1,则反码小数的表示范围为-(1-)≤x≤1-。
若字长为n+1,则反码整数的表示范围为-(-1)≤x≤-1。
真值零的反码表示不唯一。[+0]反 = 0000 / [-0]反 = 1111。
3.补码
表示:对于正数,补码与原码的表示相同,[x]补=[x]原
对于负数,原码符号位不变,数值部分按位取反,末位加1。【此规则同样适用于由[x]补求[x]原】
示例:
注意:
若字长为n+1,则补码小数的表示范围为-1≤x≤1-。
若字长为n+1,则补码整数的表示范围为-≤x≤-1。
真值零的补码表示是唯一的。[+0]补 = [-0]补 = 0000。多出的1000(2)在十进制小数中可表示为-1,在整数中可表示为-,如在8位补码中,1000000(2)表示数值-128(10)。
4.移码
表示:补码基础上符号位取反。
示例:
注意:移码只能用于表示整数。