为什么Java byte 类型的取值范围是-128~127

在计算机内,定点数有3种表示法:原码、反码和补码


[原码]就是前面所介绍的二进制定点表示法,即最高位为符号位,“0”表示正,“1”表示负,其余位表示数值的大小。


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


[补码]表示法规定:正数的补码与其原码相同;负数的补码是在其反码的末位加1。


Java使 用 补 码 来 表 示 二 进 制 数 ,在 补 码 表 示 中 ,最 高 位 为符号 位 ,正 数 的 符 号 位 为 0,负 数 为 1

如:-42 

原码:10101010

反码:11010101(原码逐位取反,但符号位除外)

补码:11010110(反码的末位加1)


确定byte是1个字节,也就是8位 负数的补码是该 数 绝 对 值 的 原 码 按 位 取 反 ,然 后 对 整个数 加 1

最大的应该是0111 1111 即127
最小的应该是1000 0000 即-128(按位取反,然后对整数加1)


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值