如何求源码 反码 补码及byte的取值范围

我们在求原码反码补码的问题用二进制转换来求。

原码

计算机源代码的最终目的是将人类可读的文本翻译成为计算机可以执行的二进制指令。
举例:
int类型的数字10=(1*2^3) +(0 * 2^2)+(1 * 2^1 )+ (0 * 2^0),
它的原码是:
00000000 00000000 00000000 00001010
因为int类型在java中为4字节,它有32位。第一位为符号位。
正数的符号位为’0’;复数的符号位为’1’。
所以int类型的数字-10,它的源码是:
10000000 00000000 00000000 00001010

反码

反码通常是用来由原码求补码或者由补码求原码的过渡码。
正数的反码和源码相同,负数的反码除符号位外其余各位按位取反。
举例:
10的反码是:
00000000 00000000 00000000 00001010
-10的反码是:
11111111 11111111 11111111 11110101

补码

在计算机中,数值一律用补码来表示和存储。
整数的源码,反码,补码都相同;复数的补码等于将其原码除符号位外的所有位取反后+1
同一个数字在不同的补码表示形式中是不同的。
比如-128的补码:
在8位二进制中表示:10000000
在16位二进制中表示:11111111 1000000

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值