Java Byte取值范围原理

本文深入解析了Java中Byte类型的取值范围,从补码的角度详细解释了最大正数127和最小负数-128是如何计算得出的,并通过实例说明了负数的二进制表示方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Java Byte 的取值范围大家都知道(-128 ~ 127),那么-128 和 127 这两个数是怎么计算的呢?

#大学知识回顾:

概念:负数的补码是该 数 绝 对 值 的 原 码 按 位 取 反 ,然 后 对 整个数 加 1

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

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

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

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

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

现在进行java Byte 取值范围分析:

      1、确定byte是1个字节,也就是8位

      2、对于计算机来说,二进制最大的正数是01111111 转换成十进制为:127

      3、最小的负数: 10000000,即-128   

二进制负数的值:取反加一,所以 10000000 的值为:
1. 取反 -> 01111111    127
2. 加一  ->  128
3. 加上符号:  -128

负数的二进制 = 正数(该数的绝对值)的二进制反码 + 1

例如:-5

第一步取绝对值:-5 的绝对值:5

第二步转二进制:5的二进制:0000 0101

第三步取反码:   0000 0101 的反码 1111 1010

第四步加一:      1111 1010 加一 1111 1011

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

遇君行

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值