源码1的反码是,是不是原码除了符号位另外为数全部相反的编码?补码是不是只要源码1的反码是加上1就可以了?

本文从原码讲起通过简述原码,反码和补码存在的作用加深对补码的认识。力争让你对补码的概念不再局限于:负数的补码等于反码加一

接触过计算机或电子信息楿关课程的同学,应该都或多或少看过补码这哥仨每次都是在课本的最前几页,来上这么一段:什么反码是原码除符号位按位取反。補码等于反码加一然后给整得莫名其妙,稀里糊涂地接着就是翻页,反正后面的内容也跟三码没多大关系

我原来也是看了好几遍都沒看懂。古人云:事不过三学C语言的时候,看过一次不懂?看《计算机基本组成原理》的时候看过还是不懂!到了大三,上《单片微机原理与接口技术》的时候仍旧是不懂到了期末,复习的时候和宿舍的人瞎聊。说讲讲这些码呀我说我也不是很清楚呀。然后就┅边说怎么求码一边算。玩着玩着突然就明白了。我说好打住。不说了放假我在好好整理下思路,于是就有了这篇额。算讨论帖吧

好了,废话不多说开始我们的原码,反码补码之旅。

认识二进制十六进制。会二进制与十进制的相互转化运算

由计算机的硬件决定任何存储于计算机中的数据,其本质都是以二进制码存储

根据冯~诺依曼提出的经典计算机体系结构框架。一台计算机由运算器控制器,存储器输入和输出设备组成。其中运算器只有加法运算器,没有减法运算器(据说一开始是有的后来由于减法器硬件开銷太大,被废了 )

所以计算机中的没法直接做减法的,它的减法是通过加法来实现的你也许会说,现实世界中所有的减法也可以当成加法的减去一个数,可以看作加上这个数的相反数当然没错,但是前提是要先有负数的概念这就为什么不得不引入一个该死的符号位。

而且从硬件的角度上看只有正数加负数才算减法。
正数与正数相加负数与负数相加,其实都可以通过加法器直接相加

原码,反碼补码的产生过程,就是为了解决计算机做减法和引入符号位(正号和负号)的问题。

本文可能比较长没必要一下子读完。原码反码,补码按章读。
重点在于讲补码到了补码可能有些绕,建议带着笔写出二进制数一起算。

表达可能不够清楚严谨望见谅。

原碼:是最简单的机器数表示法用最高位表示符号位,‘1’表示负号‘0’表示正号。其他位存放该数的二进制的绝对值

若以带符号位嘚四位二进值数为例

 1010 : 最高位为‘1’,表示这是一个负数,其他三位为‘010’
 所以1010表示十进制数(-2)。

下图给出部份正负数数的二进制原码表示法
OK原码表示法很简单有没有,虽然出现了+0和-0但是直观易懂。
于是我们高兴的开始运算。

1+(-1)=-2,这仿佛是在逗我呢

于是我們可以看到其实正数之间的加法通常是不会出错的,因为它就是一个很简单的二进制加法

而正数与负数相加,或负数与负数相加就要引起莫名其妙的结果,这都是该死的符号位引起的0分为+0-0也是因他而起。

所以原码虽然直观易懂,易于正值转换但用来实现加减法嘚话,运算规则总归是太复杂于是反码来了。

我们知道原码最大的问题就在于一个数加上他的相反数不等于零。

于是反码的设计思想僦是冲着解决这一点既然一个负数是一个正数的相反数,那我们干脆用一个正数按位取反来表示负数试试

反码:正数的反码还是等于原码

负数的反码就是他的原码除符号位外,按位取反

若以带符号位的四位二进制数为例:

3是正数,反码与原码相同则可以表示为0011
-3的原碼是1011,符号位保持不变低三位(011)按位取反得(100)
 
下图给出部分正负数的二进制数反码表示法



对着上图,我们再试着用反码的方式解决┅下原码的问题

互为相反数相加等于0解决。虽然是得到的结果是1111也就是-0

 
好我们再试着做一下两个负数相加
 
噢,好像又出现了新问题
 
不過好像问题不大因为1011(是-4的反码,但是从原码来看他其实是-3。巧合吗)
 
确实是巧合,看来相反数问题是解决了但是却让两个负数楿加的出错了。
但是实际上两个负数相加出错其实问题不大。我们回头想想我们的目的是什么是解决做减法的问题,把减法当成加法來算

两个正数相加和两个负数相加,其实都是一个加法问题只是有无符号位罢了。而正数+负数才是真正的减法问题

 
也就是说只要正數+负数不会出错,那么就没问题了负数加负数出错没关系的,负数的本质就是正数加上一个符号位而已
在原码表示法中两个负数相加,其实在不溢出的情况下结果就只有符号位出错而已(11)
反码的负数相加出错其实问题不大。我们只需要加实现两个负数加法时将两個负数反码包括符号位全部按位取反相加,然后再给他的符号位强行置‘1’就可以了
所以反码表示法其实已经解决了减法的问题,他不僅不会像原码那样出现两个相反数相加不为零的情况而且对于任意的一个正数加负数,如:
0001(1)+1101(-2)=1110(-1) 计算结果是正确的所以反码與原码比较,最大的优点就在于解决了减法的问题。
但是我们还是不满足为什么 11 (1+(-1)=-0) 为什么是-0
而且虽然说两个负数相加问题不大但是问题不大,也是问题呀好吧,处女座接下来就介绍我们的大boss补码

补码:正数的补码等于他的原码
负数的补码等于反码+1
(这呮是一种算补码的方式,多数书对于补码就是这句话)

 
在《计算机组成原理中》补码的另外一种算法 是

负数的补码等于他的原码自低位姠高位,尾数的第一个‘1’及其右边的‘0’保持不变左边的各位按位取反,符号位不变

 
OK,补码就讲完了再见!!
还是莫名其妙有没囿,为什么补码等于反码加1为什么自低位向高位取反...................?

其实上面那两段话,都只是补码的求法而不是补码的定义。很多人以为求补码就偠先求反码其实并不是。

 
那些鸡贼的计算机学家并不会心血来潮的把反码+1就定义为补码。只不过是补码正好就等于反码加1罢了

所以,忘记那些书上那句负数的补码等于它的反码+1就这句话把我们带入了理解的误区。

 
这就是后来我明白为什么我看的那本《计算机组成原悝》要特意先讲补码,再讲反码
然后说负数的补码等于他的原码自低位向高位,尾数的第一个‘1’及其右边的‘0’保持不变左边的各位按位取反,符号位不变
但是上面这句话,同样不是补码的定义它只是补码的另外一种求法。它的存在告诉我们忘记那句该死的‘反码+1’它并不是必须的。
如果你有兴趣了解补码的严格说法,我建议你可以看一下《计算机组成原理》它会用‘模’和‘同余’的概念,严谨地解释补码
接下来我只想聊聊补码的思想。

补码的思想第一次见可能会觉得很绕,但是如果你肯停下来仔细想想绝对会覺得非常美妙。

补码的思想其实就来自于生活只是我们没注意到而已。时钟经纬度,《易经》里的八卦

补码的思想其实就类似于生活中的时钟

 
好吧,我其实不想用类似好像这种词,因为类比的终究不是事物本身。而且不严谨会让我怀疑我不是工科僧说得好像我嚴谨过似的,哈哈

如果说现在时针现在停在10点钟那么什么时候时针会停在八点钟呢?

 
简单过去隔两个小时的时候,是八点钟未来过┿个小时的时候也是八点钟
也就是说时间正拨10小时,或是倒拨2小时都是八点钟
 
这个时候满12说明时针在走第二圈了,又走了8小时所以时針正好又停在八点钟。

所以12在时钟运算中称之为模,超过了12就会重新从1开始算了

 
也就是说, 10-2和10+10从另一个角度来看是等效的它都使时針指向了八点钟。

既然是等效的那在时钟运算中,减去一个数其实就相当于加上另外一个数(这个数与减数相加正好等于12,也称为同餘数)

 
这就是补码所谓模运算思想的生活例子
在这里我们再次强调原码,反码补码的引入是为了解决做减法的问题。在原码反码表礻法中,我们把减法化为加法的思维是减去一个数等于加上一个数的相反数,结果发现引入了符号位却因为符号位造成了各种意向不箌的问题。
但是从上面的例子中我们可以看到其实减去一个数,对于数值有限制有溢出的运算(模运算)来说,其实也相当于加上这個数的同余数
也就是说,我们不引入负数的概念就可以把减法当成加法来算。所以接下来我们聊4位二进制数的运算也不必急于引入苻号位。因为补码的思想把减法当成加法时并不是必须要引入符号位的
而且我们可以通过下面的例子也许能回答另一个问题,为什麼负数的符号位是‘1’而不是正数的符号位是‘1’。

好吧接下来我们就做一做四位二进制数的减法吧(先不引入符号位)

0110(6)-0010(2)【6-2=4,但是由于计算机中没有减法器我们没法算】

 
这个时候,我们想想时钟运算中减去一个数,是可以等同于加上另外一个正数(同余数)

那么这个数是什么呢从时钟运算中我们可以看出这个数与减数相加正好等于模。

 
那么四位二进制数的模是多少呢也就是说四位二进淛数最大容量是多少?其实就是2^4=16=10000B

那么2的同余数就等于=1110(14)

 


OK,我们看到按照这种算法得出的结果是10100但是对于四位二进制数,最大只能存放4位(硬件决定了)如果我们低四位,正好是0100(4)正好是我们想要的结果,至于最高位的‘1’计算机会把他放入psw寄存器进位位中。8位机则会放在cy中x86会放在cf中(这个我们不作讨论)
这个时候,我们再想想在四位二进制数中减去2,就相当于加上它的同余数14(至于它们為什么同余还是建议看《计算机组成原理》)

但是减去2,从另外一个角度来说也是加上(-2)。即加上(-2)和加上14其实得到的二进制结果除了进位位结果是一样的。

如果我们把1110(14)的最高位看作符号位后就是(-2)的补码这可能也是为什么负数的符号位是‘1’而不是‘0’

 
而且在有符号位的四位二进制数中能表示的只有‘-8~7’,而无符号位数(14)的作用和有符号数(-2)的作用效果其实是一样的
那正数嘚补码呢?加上一个正数加法器就直接可以实现。所以它的补码就还是它本身
下图给出带符号位四位二进制的补码表示法

到这里,我們发现原码反码的问题,补码基本解决了

在补码中也不存在负零了,因为1000表示-8

 
这是因为根据上面的补码图做减法时,0001(1)+1111(-1)=0000
我们洅也不需要一个1000来表示负0了就把它规定为-8

可能说得有点绕,但是实在是没办法其实我觉得补码还可以这样画。

很优美有没有如果你想想地理课本,0不就相当于本初子午线-8不就是180°,而正数相当于西经,负数相当于东经。

然后我们再来看看为什么负数的补码的求法为什么是反码+1
因为负数的反码加上这个负数的绝对值正好等于1111,再加1就是1000,也就是四位二进数的模
而负数的补码是它的绝对值的同余数鈳以通过模减去负数的绝对值,得到他的补码
所以 负数的补码就是它的补码+1。
有点绕吧只能说很难算清楚,你们还是自己算算吧还囿上面我提到的另外一种算法。
接下来我要说一下我自己算补码的小技巧。

如果我们把-8当成负数的原点那么-5的补码是多少呢?

 
-5的补码僦是-8的补码加3
所以完全可以口算出-5的补码是1011
当然也可以记住-1的补码是1111口算减法得出
对于八位加法器的话,可以把-128当补码原点十六位可鉯把-32768当补码原点。
是的128256(八位二进制数的模)的一半,3276865536(十六位二进数的模)的一半
也很方便有没有而且简单的是

补码原点总是朂高位是‘1’,其他位是‘0’

 
所以做加法总是简单得可以口算
OK,原码反码,补码之旅就到这里结束补码第一次看总会觉得很绕,想訁简意赅就怕哪里遗漏了。讲得细致又不免连自己都觉得啰里啰嗦。谢观!
当十六进制9BH和FFH分别表示为原码,补碼,反吗,移码,和无符号数时.对应的十进制数各多少?要具体过程
9BH原码转换成二进制为B正数的补码和反码与原码相同为B(如为负数反码为符号位鈈变其余数字取反 负数补码是反码的+1)二进制转十进制为从右往左1 2 4 8 16 32 64 128也就是从右往左看的2的几次方第一个为0次方第八个为7次方算得9bh十进制为 155 哃上FFH为255

反码表示法规定:正数的反码与其原码相同负数的反码是对其原码逐位取反,但符号位除外

在规定中,8位二进制码能表示的反码范围是-127~127

那么,为什么规定-128没有反码呢?下面解释

首先看-0,[-0]原码=其中1是符号位,根据反码规定算出[-0]反码=,

再看-128[-128]原码=,假如让-128也有反码根据反码规定,则[-128]反码=

你会发現,-128的反码和-0的反码相同所以为了避免面混淆,有了-0便不能有-128,这是反码规则决定的

二.原码 反码 补码的范围

你会发现,补码比其它碼多一位这是为什么呢?问题出在0上

你会发现,+0和-0的补码是一样的即 0的补码只有一种表示。

这里解释一下[-0]补码是怎么得来的

负数嘚补码就是反码整体加一。符号位上的进位舍弃(所以,舍弃了符号位的补码的第一位是数值位不是符号位,符号位舍弃了)

另外解釋一下原码符号位和补码符号位的关系补码的符号位不是保持原码的第一位不变,而是 符号位不变[-0]反码的第一个1是符号位,尾数中的7個1是数值位尾数加一后,数值位产生了进位=1 (计算补码的过程中,并不是先保证第一位不变而是保证符号位不变,保证补码规则是反码整体加一)

所以,补码能表示的数的个数中比原码反码少了一个,所以补码可以多表示一个真值为-128的数

但是,多表示的这个数-128仳较特殊只有原码和补码,没有反码

三.-128的补码为什么是

8位二进制的原值表达范围为:-127至127

共有256个组合序列 至 。
+128的原值在8位中是表达不出來的

下面从两个角度理解-128的补码为什么是.

(1)从补码的意义上去理解 

因为:256-128=256+(-128)的补码 --机器中只有加法。减法会变成补码的加法

注意:只昰规定而已,下面还有原因

于是就有了规定 定为 -128的补码
这种定法和上面数学层面的表述是一致的。

这样规定后负数的补码在机器中就恏算了。

将该负数取绝对值,再用二进制表示出这个绝对值 (不管符号位!)
对该二进制数进行取反加一操作就得到负数的补码了 (也就是求補操作!)
这种办法算出的结果符合“规定值”

    1字节 = 8位,所以它能表示的最大数当然是8位都是1(既然2进制的数只能是0或1,如果是我们常见嘚10进制那就8位都为9,这样说你该懂了?)

1字节的二进制数中最大的数:。

负数在计算机中如何表示呢

这一点,你可能听过两种不哃的回答

一 种是教科书,它会告诉你:计算机用“补码”表示负数可是有关“补码”的概念一说就得一节课,这一些我们需要在第6章Φ用一章的篇幅讲2进制的一切再 者,用“补码”表示负数其实是一种公式,公式的作用在于告诉你想得到问题的答案,应该如何计算却并没有告诉你为什么用这个公式就可以得到答案! -----我就是被这个弄混淆的>_<

另 一种是一些程序员告诉你的:用二进制数的最高位表示苻号,最高位是0表示正数,最高位是1表示负数。这种说法本身没错可是如果没有下文,那么它就是 错的至少它不能解释,为什么芓符类型的-1用二进制表示是“”(16进制为FF);而不是我们更能理解的“”(为什么说后者更好理解呢?因为既然说最高位是1时表示负数那1000 0001鈈是正好是-1吗?-----re!当初偶就是这么想的so一直在脑中打架,越打越混淆==)。

2.1、你自已决定是否需要有正负

就像我们必须决定某个量使用整数还是实数,使用多大的范围数一样我们必须自已决定某个量是否需要正负。如果这个量不会有负值那么我们可以定它为带囸负的类型。

在计算机中可以区分正负的类型,称为有符类型无正负的类型(只有正值),称为无符类型

数值类型分为整型或实型,其中整型又分为无符类型或有符类型而实型则只有有符类型。

字符类型也分为有符和无符类型

比如有两个量,年龄和库存我们可鉯定前者为无符的字符类型,后者定为有符的整数类型

 3、无符号数和有符号数的范围区别。

  同样是一个字节无符号数的最大值是255,而有符号数的最大值是127原因是有符号数中的最高位被挪去表示符号了。并且我们知道,最高位的权值也是最高的(对于1字节数来说昰2的7次方=128)所以仅仅少于一位,最大值一下子减半

不过,有符号数的长处是它可以表示负数因此,虽然它的在最大值缩水了却在負值的方向出现了伸展。我们仍一个字节的数值对比:

同样是一个字节无符号的最小值是 0 ,而有符号数的最小值是-128所以二者能表达的鈈同的数值的个数都一样是256个。只不过前者表达的是0到255这256个数后者表达的是-128到+127这256个数。

一个有符号的数据类型的最小值是如何计算出来嘚呢

有符号的数据类型的最大值的计算方法完全和无符号一样,只不过它少了一个最高位(见第3点)但在负值范围内,数值的计算方法不能直接使用1* 26 + 1* 25 的公式进行转换在计算机中,负数除为最高位为1以外还采用补码形式进行表达。所以在计算其值前需要对补码进行還原。这里先直观地看一眼补码的形式:

以我们原有的数学经验,在10进制中:1 表示正1而加上负号:-1 表示和1相对的负值。

那么我们会佷容易认为在2进制中(1个字节): 表示正1,则高位为1后:应该表示-1

然而,事实上计算机中的规定有些相反请看下表:

1000 0000红色的1代表负数藍色的是补码(补码=反码+1)
1000 0001蓝色部分代表多大的值?:将补码还原为原码 -127想化成负数:先减去1按位取反

首先我们看到,从-1到-128其二进制的朂高位都是1(表中标为红色),正如我们前面的学

然后我们有些奇怪地发现, 并没有拿来表示 -0;而也不是拿来直观地表示-1事实上,-1 用來表示

怎么理解这个问题呢?先得问一句是-1大还是-128大

当 然是 -1 大。-1是最大的负整数以此对应,计算机中无论是字符类型或者是整数類型,也无论这个整数是几个字节它都用全1来表示 -1。比如一个字节的数值中:表示-1那么, - 1 是什么呢和现实中的计算结果完全一致。 - 1 = 1111 1110而就是-2。这样一直减下去当减到只剩最高位用于表示符号的1以外,其它低位全为0时就是最小的负值了,在一字节中最小的负值是,也就是-128

--------小米批注:就是这部分蓝色的文字,让我终于能记清楚-1的编码方式了汗=。=

我们以-1为例来看看不同字节数的整数中,如哬表达-1这个数:

红色表示负数蓝色部分的补码为值1
负数:原码就是原来的表示方法、反码是除符号位(最高位)外取反、补码=反码+1双字节數

可 能有同学这时会混了:为什么 有时表示255有时又表示-1?

所以我再强调一下本节前面所说的第2点:你自已决定一个数是有符号还是无符號的写程序时,指定一个量是有符号的那么 当这个量的二进制各位上都是1时,它表示的数就是-1;相反如果事先声明这个量是无符号嘚,此时它表示的就是该量允许的最大值对于一个字节的数来说, 最大值就是255

ok 摘抄暂告段落,其实原文对于c的一些基础数据类型知识介绍的非常详细8过太长了,摘到我需要的内容后就没全帖过来如果有需要学习的同学,建议参见原文:)

    在计算机内部所有信息都昰用二进制数串的形式表示的。整数通常都有正负之分计算机中的整数分为无符号的和带符号的。无符号的整数用来表示0和正整数 带苻号的证书可以表示所有的整数。由于计算机中符号和数字一样都必须用二进制数串来表示,因此正负号也必须用0、1来表示。通常我們用最高的有效位来 表示数的符号(当用8位来表示一个整数时第8位即为最高有效位,当用16位来表示一个整数时第16位即为最高有效位。)0表示正号、1表示负号这种 正负号数字化的机内表示形式就称为“机器数”,而相应的机器外部用正负号表示的数称为“真值”将一個真值表示成二进制字串的机器数的过程就称为编码。

    无符号数没有原码、反码和补码一说只有带符号数才存在不同的编码方式。

带符號整数有原码、反码、补码等几种编码方式原码即直接将真值转换为其相应的二进制形式,而反码和补码是对原码进行某种转换编码方式正整数的原 码、反码和补码都一样,负数的反码是对原码的除符号位外的其他位进行取反后的结果(取反即如果该位为0则变为1而该位为1则变为0的操作)。而补码是先 求原码的反码然后在反码的末尾位加1 后得到的结果,即补码是反码+1IBM-PC中带符号整数都采用补码形式表礻。(注意只是带符号的整数采用补码存储表示的,浮点数另有其存储方式)

    1)因为使用补码可以将符号位和其他位统一处理,同时减法也可以按加法来处理,即如果是补码表示的数不管是加减法都直接用加法运算即可实现。

    2)两个用补码表示的数相加时如果最高位(符号位)有进位,则进位被舍弃

    1)使符号位能与有效值部分一起参加运算,从而简化运算规则从而可以简化运算器的结构,提高运算速度;(减法运算可以用加法运算表示出来)

    2)加法运算比减法运算更易于实现。使减法运算转换为加法运算进一步简化运算器线路设计

    下面深入分析上面所陈述的采用补码的原因(目的)

    用带符号位的原码进行乘除运算时结果正确,而在加减运算的时候就出現了问题,如下:假设字长为8bits

    因为在两个整数的加法运算中是没有问题的于是就发现问题出现在带符号位的负数身上,对除符号位外的其余各位逐位取反就产生了反码反码的取值空间和原码相同且一一对应。下面是反码的减法运算:

于是就引入了补码概念负数的补码僦是对反码加一,而正数不变正数的原码反码补码是一样的。在补码中用(-128)代替了(-0)所以补码的表示范围为:

    采用补码表示还有另外一个原因,那就是为了防止0的机器数有两个编码原码和反码表示的0有两种形式+0和-0,而我们知道+0和-0是相同的。这 样8位的原码和反码表示的整数的范围就是-127~+127(11111),而采用补码表示的时候是+0, 即0;不再是-0而是-128,这样补码表示的数的范围就是-128~+127了,不但增加了一个数得表示范圍而且还保证了0编码 的唯一性。

接下来的问题是如何能将减法运算转换成加法运算呢?

我们已经知道原码表示简单直观,与真值转換容易但如果用原码表示,其符号位不能参加运算在计算机中用原码实现算术运算时,要取绝对值参加运算符号位单独处理,这对塖除运算是很容易实现的但对加减运算是非常不方便的,如两个异号数相加实际是要做减法,而两个异号数相减实际是要做加法。茬做减法时还要判断操作数绝对值的大小,这些都会使运算器的设计变得很复杂而补码这种编码方式实际上正是针对上述问题的。通過用补码进行表示就可以把减法运算化为加法运算。

    在日常生活中有许多化减为加的例子。例如时钟是逢12进位,12点也可看作0点当將时针从10点调整到5点时有以下两种方法:

    一种方法是时针逆时针方向拨5格,相当于做减法:

    另一种方法是时针顺时针方向拨7格相当于做加法:

    这是由于时钟以12 为模,在这个前提下当和超过12时,可将12舍去于是,减5相当于加7同理,减4可表示成加8减3可表示成加9,…

    在數学中,用“同余”概念描述上述关系即两整数A、B用同一个正整数M (M称为模)去除而余数相等,则称A、B对M同余记作:

    具有同余关系的两个數为互补关系,其中一个称为另一个的补码当M=12时,-5和+7-4和+8,-3和+9就是同余的它们互为补码。

    从同余的概念和上述时钟的唎子不难得出结论:对于某一确定的模,用某数减去小于模的另一个数总可以用加上“模减去该数绝对值的差”来代替。因此在有模运算中,减法就可以化作加法来做

    可以看出,补码的加法运算所依据的基本关系为:

    至于加法运算为什么比减法运算易于实现以及CPU如哬实现各种算术运算等问题则需要通过对数字电路的学习来理解CPU的运算器的硬件实现问题的相关内容了。

1.一个二进制数的补码的补码就昰原码!!!

比如:真值-3原码,补码

也可以从补码的数学含义理解。

2.几个特殊的补码记忆:(一般是8位不是8位和8的倍数位的,在实際应用中没有意义所以一般都是变换成成8位的二进制数。因为实际应用中一般都是补码表示,所以着重记忆补码)

+1~+127的补码都是原码補码逐渐加一。

-1~-127的补码都是其反码加一补码逐渐加一。

虽然补码的原码是多少 不够直观但是补码反映出的负数的大小是直观的,补码夶小顺序和真值保持一致

负数真值中,-1最大-128最小,

负数补码中-1补码是,...-127补码是,-128补码是

在负数的补码中,直观上可以看出-1的補码是最大的:, -128的补码是最小的:

因为有补码,所以是有符号数80H即原码,即真值-0所以80H的补码是。

8位二进制数时表示不下+128,16位二進制数时可以表示因为+128=00

不包括+128。-128也只在补码表示中有-128的原码和反码在8位二进制数时也都没有,在16位及以上可以表示

七.探究求补码的朂好的方法

-0的原码是 ,反码 补码 ,可以反码加一可以对-1求补操作。

-3的原码是 反码 ,补码 可以反码加一,可以对-3求补操作

由上面彡个例子可以看出,求补码的最快捷的方法第一位不变什么的 只适用于不是-1 -128的大部分数!

最统一的方法,应该是:

有反码的反码加一(其中,符号位有进位的 舍弃符号位 只保留数值位比如-0的补码。更重要的是-0的补码 是规定)或者求补操作。

没有反码的求补操作。仳如-128

所以说,求补操作才是对-128~+127唯一全部使用的求补码的方法。

这样也就解释了为什么所有补码都可以用补码减法运算了,因为求补操作对所有真值都适用

求补操作:就是求(负数的)补码

求补操作:不管符号位(不是符号位保持不变!也不是第一位保持不变!就是呮用负数的绝对值,根本没用到符号位)取负数(真值)的绝对值(即将负数的符号位变为0),对绝对值按位取反(可以认为绝对值是無符号数)然后加一。就得到了负数的补码

求补操作对于求-0,-128也都适用

例子:求3CH-90H。分为有符号数和无符号数时

3CH 和90H 不是真值!只有┿进制是真值,而 十六进制或者八进制 都是为了书写二进制码方便所以才说3CH可能是无符号数 也可能是有符号数!

3CH 和90H 就是两个二进制码!這两个二进制码可能是无符号数或者有符号数!

二进制码(二进制数)分为有符号数和无符号数。

有符号数时X-Y=X+(-Y)补,所以求-90H的补码,即求-的补码即对-求补操作!不是对求补操作!90H是绝对值,-90H是真值是绝对值的二进制码。

这里解释一下题目要求的意思:

(1)机器只認识二进制十六进制和八进制是为了人书写简洁而设立的。

(2)有符号数和无符号数说的都是二进制数(二进制码)

3CH的二进制码是唯┅的,但是当它是有符号数时和是无符号数时 的真值显然是不同的

我要回帖

更多关于 源码1的反码是 的文章

 

随机推荐