C语言 深入理解原码,反码,补码

本文深入探讨了C语言中数值的原码、反码和补码表示方式。针对计算机中为什么使用原码、反码和补码的原因,文章通过实例解释了原码运算的问题,反码解决了减法但导致0的符号问题,而补码不仅解决了0的符号问题,还能扩大表示范围,使得8位二进制可以表示-128到127的整数。文章通过数学原理介绍了反码和补码的发明过程,并提供了各种码之间的转换关系。
摘要由CSDN通过智能技术生成

一:前提引入

在计算机中,一个字节8位,可以表示2^8=256没有符号数那就是-128~+128,但实际上范围却是-128到127,这是为什么?其实产生这个问题的根本原因就是我们习惯用人的思维来思考计算机做的事。在探究原因之前,我们先来看一下学过的几种编码方式。

二:编码方式介绍

(1)原码

原码就是符号位加上真值的绝对值, 即用第一位表示符号, 其余位表示值。比如如果是8位二进制。
[+1]原 = 0000 0001
[-1]原 = 1000 0001
第一位是符号位. 因为第一位是符号位, 所以8位二进制数的取值范围就是:
[1111 1111 , 0111 1111]

[-127 , 127]
原码是人脑最容易理解和计算的表示方式。

(2)反码

正数的反码是其本身
负数的反码是在其原码的基础上,符号位不变,其余各个位取反。
[+1] = [00000001]原 = [00000001]反
[-1] = [10000001]原 = [11111110]反
可见如果一个反码表示的是负数, 人脑无法直观的看出来它的数值. 通常要将其转换成原码再计算.

(3)补码

正数的补码就是其本身
负数的补码是在其原码的基础上,,符号位不变, 其余各位取反, 最后+1。(即在反码的基础上+1)
[+1] = [00000001]原 = [00000001]反 = [00000001]补
[-1] = [10000001]原 = [11111110]反 = [11111111]补
对于负数, 补码表示方式也是人脑无法直观看出其数值的. 通常也需要转换成原码在计算其数值。

三:使用源码、反码和补码的原因

现在我们知道了计算机可以有三种编码方式表示一个数。对于正数因为三种编码方式的结果都相同:
[+1] = [00000001]原 = [00000001]反 = [00000001]补
所以不需要过多解释。但是对于负数:
[-1] = [10000001]原 = [11111110]反 = [11111111]补

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

是智造哎

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值