原码、反码、补码

原码、反码、补码

原码:
* 最高位为符号位,符号位为0表示正数,符号位为1表示负数
* 其余部分用二进制的绝对值表示

// 7的原码
0000 0111
// -1的原码
1000 0111

反码:
* 正数,原码与反码相同
* 负数,在原码的基础上,符号位不变,其余部分取反

// 7的反码
0000 0111
// -7的反码
1111 1000

补码:
* 正数,原码、反码和补码都相同
* 负数,在反码的基础上,末位加1

// 7的补码
0000 0111
// -7的补码
1111 1001

存储方式与计算

  • 数值在计算机中,以补码存储
  • 运算也是在补码的基础上进行的
// 1 + 1
0000 0001 ; 1
0000 0001 ; 1
0000 0010 ; 2
// 2 - 1 = 2 + (-1)
 0000 0010 ; 2
 1111 1111 ; -1
10000 0001 ; 1byte存储最高位的1被丢弃

取值范围

byte为例

-127 ~ 127

// 整数最大, 符号位为0,其余都是1, 那位10进制为127
0111 1111 ; 原码、反码、补码
// 负数最大,符号位为1,其余也为1, 那么10进制为-127
1111 1111 ; 原码
1000 0000 ; 反码
1000 0001 ; 补码

0

// +0
0000 0000 ; 原码、反码、补码都一样
// -0
 1000 0000 ; 原码
 1111 1111 ; 反码
10000 0000 ; 补码、最高位1被丢弃,所以+0和-0的存储是一样

-128

// byte有8位,一共2的8次方,256种组合,-127~127一共是255种,还剩下一种 1000 0000
// 以下仅是个人理解
// 由于最高位是符号位,所以不能是正数,那么假设它是负数
1 1000 0000 ; 补码
// 末位-1
1 0111 1111 ; 反码
// 取反
1 1000 0000 ; 原码 ; -128

因此,我认为1000 0000是-128,有三个原因:
1. 1000 0000 必须表示一个数,不用白不用啊
2. 正数最高位不能为0
3. -128, 除去符号位不说,其余位刚刚好满足128

总结

取值范围:(2的n-1)-1 ~ -(2的n-1)

  • n-1 是由于从0次方开始
  • 整数比负数多1是因为-128的原因
原码反码补码计算口诀是: 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 ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值