无符号整数没有符号位,因此只能表示正数,全部位置都用来表示数值。
8位二进制无符号整数所能表示的范围是0~256
首先要明确,原码、反码、补码都是有符号整数的表示方法,在实际应用中,最常用的是补码表示法。
有符号整数的表示方法主要有以下三种:
-
原码(:原码表示法中,最高位(符号位)用于表示整数的正负(0表示正数,1表示负数),其余位表示数值的大小。原码表示法的优点是直观易懂,但在进行算术运算时需要分情况讨论,使得计算过程变得复杂。
-
反码:反码表示法中,正数的反码与原码相同;负数的反码是保留符号位为1,然后对原码的数值位取反(0变为1,1变为0)。
-
补码:补码表示法是计算机中最常用的有符号整数表示方法。正数的补码与原码相同;负数的补码是保留符号位为1,然后对原码的数值位取反,最后加1。补码表示法的优点是加法运算简单且唯一,不需要区分正负数,而且没有重复的零表示。
在实际计算机系统中,补码表示法是最常用的有符号整数表示方法,因为它能简化计算机硬件的设计和算术运算的实现。
补码表示法允许我们对正数和负数使用相同的加法规则。在补码表示法下,无论操作数是正数还是负数,计算机都可以执行相同的硬件加法操作,并且也无需判断操作数的正负。这大大简化了计算机硬件的设计。
补码也可以理解为就是一个数的表现方式,它既可以表示正数也可以表示负数。我们在具体计算一个补码表现的数值的时候,可以将其转化为原码,然后再计算其数值。
或者也可以通过另外一种计算方法,以8进制为例,首个符号位为1,则代表-2^7,则
1111 1111代表的是 -2^7+2^6+2^5+2^4+2^3+2^2+2^1=-1
- 8位二进制原码的表示范围是多少?
8位二进制原码,最高位(第8位)是符号位,剩下的7位表示数值。所以,我们可以表示的数值范围是从0到2^7 - 1(即127)。
符号位为0表示正数,为1表示负数。因此,8位二进制原码可以表示的范围是:
-127 到 -1 (负数) 0 到 127 (正数和零)
总结一下,8位二进制原码的表示范围是从 -127 到 127。
- 8位二进制有符号整数的表示范围是多少?
8位二进制有符号整数,通常使用补码来表示负数。最高位(第8位)是符号位,剩下的7位表示数值。所以,我们可以表示的数值范围是从0到2^7 - 1(即127)。
符号位为0表示正数,为1表示负数。在补码表示法中,负数的范围是从-2^7(即-128)到-1。正数的范围是从0到2^7 - 1(即127)。
总结一下,8位二进制有符号整数(补码表示法)的表示范围是从 -128 到 127。
- 原码和补码如何互相转换?
原码到补码的转换上面有写。如果是正数的话表示相同。如果是负数的话,补码到原码的转换,就是-1,然后再取反(不对符号位进行操作)。
也有另外一种方法:
- 从右到左,找到第一个 1,将该位及其左边的所有位保持不变。
- 将该位右边的所有位取反(0 变为 1,1 变为 0)。
- 为什么补码有利于运算器的加法计算?
事实上,
补码的功能,类似于:
时针倒拨 3 小时,与正拨 9 小时,效果相同。
利用这种思路,计算机中的负数,也可以改为正数(即补码)。
同时,减法运算,也就可以用加法运算代替了。
那么,借助于补码,就能统一加减法,够简化计算机的硬件。
十进制比较容易理解:
25 - 1 = 24
25 + 99 = (一百) 24。
只要忽略进位,+99 就能代替-1。
+99 就称为-1 的补数。
在这里用了 2 位 10 进制。
求补数的算法:补数 = 负数 + 10^2。
通用的公式是:补数 = 负数 + 10^n。 n 是位数。
-----------------------
计算机用二进制,补数,就改名为:补码。
一个字节,是 8 位 2 进制。
计数范围是:0000 0000 ~ 1111 1111(十进制 255)。
计数周期是:2^8 = 256。
求补码的算法:负数的补码=负数+2^n。
那么:
-1 的补码=-1 + 256 = 255 = 1111 1111。
-2 的补码=-2 + 256 = 254 = 1111 1110。
。。。
例如,7-2 = 5,用补码计算如下:
7 = 0000 0111
[-2] 补 = 1111 1110
---相加------------
得: (1) 0000 0101 = 5
舍弃了进位,结果就完全正确。
借助于补码,负数就没有了,从而就把“减法转换为加法运算”。
补充:
- 为什么我有些人的代码里会用到unsigned int?
unsigned int
是一种无符号整数类型,它只能表示非负整数。与有符号整数类型(例如 int
)相比,unsigned int
有一些特点和用途:
-
范围:由于
unsigned int
不需要表示负数,它的值域是 0 到最大正数的两倍。这意味着它可以表示更大的整数。例如,在一个 32 位系统上,int
的范围是 -2,147,483,648 到 2,147,483,647,而unsigned int
的范围是 0 到 4,294,967,295。 -
位运算:当你需要对整数进行位运算(如按位与、按位或、按位异或等)时,使用
unsigned int
可以避免一些与符号位相关的问题。由于unsigned int
是无符号的,所以位运算更直观且不易出错。 -
用途:
unsigned int
常用于表示计数器、索引、大小、哈希值等,这些场景下的值通常是非负的。使用unsigned int
可以明确表示这些值应始终为非负。 -
溢出行为:
unsigned int
的溢出行为是定义良好的,按照模数算术(模 2^n,n 为位数)进行。这意味着,当一个unsigned int
值达到其最大值并继续增加时,它会回绕到 0。这在某些应用中可能是所需的行为。
然而,需要注意的是,unsigned int
也可能导致一些不易察觉的错误。例如,在涉及混合类型运算时,unsigned int
可能会导致意外的类型提升和隐式类型转换。因此,在使用 unsigned int
时,要确保正确处理这些可能的问题。