话不多说直接干货,请耐心看完!
对于一个数字来说,有正负之分,但是如何让二进制数表示负数是个问题
首先要明白一个基本概念,那就是十进制的数如何表达二进制数,8 4 2 1的方法大家应该都知道吧,简单点来说,8 4 2 1这个方法可以快速的表达任何的4位二进制的数,看下面
1 0001
2 0010
3 0011
4 0100
5 0101
6 0110
7 0111
8 1000
16 0001 0000
32 0010 0000
64 0100 0000
128 1000 0000
对于无符号位的8位二进制数,那么这8位二进制数只是表示一个数值(0000 0000 ~ 1111 1111)
也就是8位无符号二进制数的取值范围(0~255)为什么是255?因为1111 1111=从最右边开始1+2+4+8+16+32+64+128=255。
而对于有符号位的8位二进制数来说,那么这8位二进制数表示正负(1000 0000 ~0111 1111)也就是(-128 ~ 127)
最高位是1代表的是负数,最高位是0代表的是正数
那么为什么1000 0000代表的是-128,首先要明白方法,原码取反然后加1,哎,这些不重要,什么原码补码的,直接看例子
第一步:1000 0000取反得到0111 1111
第二步:0111 1111加1得到1000 0000
1000 0000就是128,因为第一步原码里面的1000 0000的最高位是1,所以第二步得到的数1000 0000就是-128
而对于0111 1111很显然最高位是0,那么这个8位二进制数代表的就是一个正数直接加就行
0111 1111=1+2+4+8+16+32+64=127