原码、反码、补码,有符号整数,无符号整数的关联与区别

无符号整数没有符号位,因此只能表示正数,全部位置都用来表示数值。

8位二进制无符号整数所能表示的范围是0~256

首先要明确,原码、反码、补码都是有符号整数的表示方法,在实际应用中,最常用的是补码表示法。

有符号整数的表示方法主要有以下三种:

  1. 原码(:原码表示法中,最高位(符号位)用于表示整数的正负(0表示正数,1表示负数),其余位表示数值的大小。原码表示法的优点是直观易懂,但在进行算术运算时需要分情况讨论,使得计算过程变得复杂。

  2. 反码:反码表示法中,正数的反码与原码相同;负数的反码是保留符号位为1,然后对原码的数值位取反(0变为1,1变为0)。

  3. 补码:补码表示法是计算机中最常用的有符号整数表示方法。正数的补码与原码相同;负数的补码是保留符号位为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. 从右到左,找到第一个 1,将该位及其左边的所有位保持不变。
  2. 将该位右边的所有位取反(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 有一些特点和用途:

  1. 范围:由于 unsigned int 不需要表示负数,它的值域是 0 到最大正数的两倍。这意味着它可以表示更大的整数。例如,在一个 32 位系统上,int 的范围是 -2,147,483,648 到 2,147,483,647,而 unsigned int 的范围是 0 到 4,294,967,295。

  2. 位运算:当你需要对整数进行位运算(如按位与、按位或、按位异或等)时,使用 unsigned int 可以避免一些与符号位相关的问题。由于 unsigned int 是无符号的,所以位运算更直观且不易出错。

  3. 用途:unsigned int 常用于表示计数器、索引、大小、哈希值等,这些场景下的值通常是非负的。使用 unsigned int 可以明确表示这些值应始终为非负。

  4. 溢出行为:unsigned int 的溢出行为是定义良好的,按照模数算术(模 2^n,n 为位数)进行。这意味着,当一个 unsigned int 值达到其最大值并继续增加时,它会回绕到 0。这在某些应用中可能是所需的行为。

然而,需要注意的是,unsigned int 也可能导致一些不易察觉的错误。例如,在涉及混合类型运算时,unsigned int 可能会导致意外的类型提升和隐式类型转换。因此,在使用 unsigned int 时,要确保正确处理这些可能的问题。

  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值