原码,反码,补码

1 篇文章 1 订阅
1 篇文章 1 订阅

1.原码

        所有的数字在计算机中的存储形式都是二进制的形式,(这里用八位二进制来比喻)比如1 在计算机中储存为0,0000001,-1在计算机中储存为1,0000001,用逗号分割开的最高位就是符号位,正数为'0',负数为'1'。

 1.1正数原码的表达

        因为最高位也就是第八位是符号位,所以八位二进制表示整数最大只能表示到0,1111111,也就是 127(128-1)。

1.2负数原码的表达

        对于负数来说就会比较好玩了,(还是用八位二进制来比喻),其实和正数的也差不多,只不过符号位从'0'变成'1'了,对应的0,0101010 和 1,0101010表示的分别为:26和-26.

        但是有一点和正数不同,1,0000000 这个原码,按理来说应该是-0,但是0和-0没有任何区别,所以计算机只需要一个0,0000000来表示0就可以,1,0000000又不能空着没意义,所以就用来表示-127的下一位,也就是-128。

        因此,也就能得出为什么八位二进制的数据表示范围是从-128到127了。

2.反码

        反码,从原码变成补码的中间值,通常情况下不进行运算使用(犯贱的不算),所以不做多解释,讲解一下转换原理,用-5举例子

原码:1,0000101

反码:1,1111010

符号位不变,其他位置按位取反,也可以看成

5

原码:0,0000101,5这个数字包括符号位一起取反(待会有用)。

3.补码

        补码,计算机中进行加减乘除运算所用的数字表示法,因为如果计算机无法分辨加减乘除(也可以说分辨起来太难)所以就通过补码,把加减乘除都转化为最基础的加运算,就快乐了许多。

        接下来说一下补码的原理:

        十进制:如果你手上有一台计算机是三位十进制(假设啊,真的有没有我也不知道),来运算一下80-30,显然知等于50,那么80+(100-30)呢,150,但是计算机看不到第三位,也就成了50,对照一看,好像是一样,所以在这种情况70和(-30)是等价的,这其实就是补码的运算原理,所以说,原码转化成补码就等于是加了一个负号。

        这样的话转化成二进制是不是也OK,那么补码怎么得到?还是用-5来说

原码:1,0000101

不看符号位只看数值位:0000101,我们要的结果是原码补码相加能进位,也就是用10000000-0000101,最后得到1111011,这就是-5的补码的数值位,接下来放一起看一下

原码:1,0000101

反码:1,1111010

补码:1,1111011

那是不是就是反码加一就OK,在数值上看一眼也是这样的0000101+1111010=1111111再加1就是10000000成功进位.

        总结:负数的原码取反加一(数值位),得到补码,再取反加一,回到原码。

        就是这么简单.

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
原码反码补码计算口诀是: 1. 原码:符号位加上真值的绝对值。 2. 反码:将原码中的符号位保持不变,其余位取反。 3. 补码反码加1。 例如,对于一个8位二进制数,如果要计算其反码,可以按照以下步骤进行: 1. 将符号位保持不变。 2. 将其余位取反。 对于补码的计算,可以按照以下步骤进行: 1. 先计算其反码。 2. 在反码的基础上加1。 这样,就可以得到原码反码补码的计算结果。 #### 引用[.reference_title] - *1* [原码, 反码, 补码的基础概念和计算方法](https://blog.csdn.net/Chinajsczlymyc/article/details/126910306)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [(转)java 原码反码补码计算 以及 取反运算,原码反码补码运算公式](https://blog.csdn.net/PacosonSWJTU/article/details/128604733)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [原码,补码,反码概念和计算方法详解](https://blog.csdn.net/qq_39541098/article/details/122729622)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值