标签:数位 一个 浮点型 === 无法 原码 反码 强制 溢出
正数的原码,补码,反码 相同, 正数用原码表示,负数用补码表示,负数用如果也用原码表示,表示范围就只有255个数 -128无法表示.
byte类型的取值范围:有符号的[-128,127] 无符号的[0,255]
对于有符号的数据类型来说:最高位为符号位 0 为正数,1为负数
例如:5 表示为 0000 0101
-5表示为( 原码):1000 0101 ===> 反码 :1111 1010 ===> 补码:1111 1011
-128 的原码,反码,补码:
-128 补码1000 0000 (1111 1111(反码) + 1 = 1000 0000,这里实际上真正相加的是1111 1111后面的7位,第1位是符号位始终不会变,所以,当进到第8位的时候,溢出了,会被舍弃)
int a = 256 ; //1 0000 0000
byte b = a ; //去高位 得到 0000 0000
//b=0
// a=255时 1111 1111 对于byte来说是负数这是一个负数的补码 ===> 原码 : 1000 0001 b= -1
在java中大数据强转位小范围数据类型:去高位
浮点型转为整型:去小数位,再去高位
标签:数位 一个 浮点型 === 无法 原码 反码 强制 溢出
原文地址:https://www.cnblogs.com/superlucky/p/9406535.html