单片机中的数是以二进制表示的,分为有符号数和无符号数两种
1 有符号数
1.1 有符号数的表示
单片机采用二进制数,所以只有“1”和“0”两种数字,单片机中的数据有8位,一般最高位为符号位,用“0”表示“+”,用“1”表示“−”;所以只有7位用来表示数值,范围为−127~+128
表示方法有三种:原码、补码、反码
原码:用“1”表示“−”,用“0”表示“+”,其他各数保持不变
补码:对于正的有符号数,其反码与原码相同;对于负的有符号数,其反码除符号位与原码相同外,其他各位数由原码各位数取反得到
反码:对于正的有符号数,其补码与反码、原码相同;对于负的有符号数,其补码除符号位与反码一致外,其他数由反码加1得到
1.2 有符号数的运算
用原码表示有符号数简单、直观,但在单片机中,如果采用原码进行减法运算,需要很复杂的硬件电路;如果用补码,可以将减法运算变为加法运算,从而省去减法器而简化硬件电路,因此单片机普遍采用补码的形式表示有符号数
例如:
用二进制减法运算和补码加法运算分别计算35−21
① 二进制减法运算:35−21=00100011−00010101=00001110
② 用补码加法运算:35−21=[+35]+[−21]=[00100011] 原+[10010101] 原=[00100011] 反+[11101010] 反=[00100011] 补+[11101011] 补=00001110(数据长度为8位,第9位自然丢失)
2 无符号数
2.1 无符号数的表示
无符号数因为不用符号位,8 位全部用来表示数据,所以这种方法可以表示的数据范围是 0~255