为什么带符号的8位二进制数是-128~127啊!而不是-127~127啊!
2013-07-15 16:22
363 查看
转自:http://blog.csdn.net/fengyunjh/article/details/6161821
因为一个带符号数和一个不带符号数一样,8位能表示256个值,如果是-127~127的话,只有255个数!那还少一个。
因为一个带符号数和一个不带符号数一样,8位能表示256个值,如果是-127~127的话,只有255个数!那还少一个。
因为7位可以表示128个数,那加上正负肯定能表示256个不同的数。
+0的补码就是其原码,也就是说是0000 0000而已(对于8位来说) -0的补码是其反码加1,其反码是1111 1111,当然,其反码加1后就是溢出一个进位后,仍然是0000 0000.
所以0和-0的补码都是0000 0000根据补码原则,0000 0000表示0,而1000 0000却不能表示-0,所以根据原则可知,-1000 0000表示的是-128.
这就是为什么8位带符号数的范围是-128~127之间了!
其实就是1000 0000表示谁呢,谁也表示不了,那就用来表示-128
相关文章推荐
- 为什么带符号的8位二进制数是-128~127啊!而不是-127~127啊!
- 为什么8位有符号数的取值范围是-128~+127
- 数据类型:整数最小值为何不是最大值的相反数(为什么八位二进制数表示范围是:-128~127 ) ?
- 解读为什么有符号的char可表示范围是-128~+127
- IEEE 754标准中,阶的偏置值为什么是127,而不是128?
- 深入理解c语言——char的范围为什么是-128到127而不是-127到127
- 为什么8位有符号数的范围为“-128 — +127”?
- 为何八位有符号整数的范围是-128~127,而不是-127~128
- 为什么8位有符号数的范围为“-128 — +127”?(转载加补充)
- 带符号的char类型取值范围为什么是-128——127
- 为什么8位有符号数的范围为“-128 — +127”?(转载加补充)
- 带符号的char类型取值范围为什么是-128——127
- Java 中的真值、机器数、原码、反码和补码:为什么整形的取值范围 不是对称的,比如 byte的取值范围为 -128到127,而不是-128到128或者-127到127?
- 为什么8位二进制的补码取值范围是-128~127
- 八位二进制数为什么表示范围(-128~~+127)理解
- 八位二进制数为什么表示范围是:-128~~+127?
- 8位有符号的取值范围是-128~+127
- 八位二进制数为什么表示范围是:-128~~+127?
- 8位有符号的取值范围是-128~+127
- 八位二进制数为什么表示范围是:-128~~+127?