java设计byte类型为1个字节,1个字节占8位,即8bit,这是常识。

另外,计算机系统中是用补码来存储的,首位为0表示正数,首位为1表示负数,所以有以下结论:

最大的补码用二进制表示为:01111111 = 127

最小的补码用二进制表示为:10000000 = -128

关于补码、原码、反码的计算原理可以百度

Byte的源码

/**

 * A constant holding the minimum value a {@code byte} can

 * have, -27.

 */

public static final byte   MIN_VALUE = -128;

/**

 * A constant holding the maximum value a {@code byte} can

 * have, 27-1.

 */

public static final byte   MAX_VALUE = 127;

7是最高位,总共8bit,可以看出byte占1个字节,即8/8=1。

Integer源码:

/**

 * A constant holding the minimum value an {@code int} can

 * have, -231.

 */

public static final int   MIN_VALUE = 0x80000000;

/**

 * A constant holding the maximum value an {@code int} can

 * have, 231-1.

 */

public static final int   MAX_VALUE = 0x7fffffff;

31是最高位,总共32bit,可以看出int占4个字节,即32/8=4。

其他Short、Long的设计原理也一样。