1.计算机中的数字存储
计算机里都是用补码存储数值的,原码、反码、补码的转换(有符号数):
原码->反码:符号位不变,其它位置取反 == >0001->0110 1001->1110
原码->补码(正数):不变,原码补码相等 ==> 0001->0001
原码->补码(负数):原码->反码后+1 ==> 1001->1110->1111
补码->原码(正数):不变,原码补码相等 ==> 0001->0001
补码->原码(负数):补码->反码后+1 ==> 1111->1000->1001
2.取值范围
类型名: 说明: 长度(字节): 取值范围
类型名 | 说明 | 长度(字节) | 取值范围 |
---|---|---|---|
bool | 布尔型 | 1 | false /ture |
[sighed] char | 有符号字符型 | 1 | -128~127 |
unsigned char | 无符号字符型 | 1 | 0~255 |
[signed] short [int] | 有符号短整型 | 2 | -32768~32767 |
unsigned short [int] | 无符号短整型 | 2 | 0~65535 |
[signed] int | 有符号整型 | 4 | -231~231-1 |
unsigned [int] | 无符号整型 | 4 | 0~232-1 |
[signed] long [int] | 有符号长整型 | 4 | -231~231-1 |
unsigned long [int] | 无符号长整型 | 4 | 0~232-1 |
float | 实型 | 4 | -10(38) ~10(38) |
double | 双精度实型 | 8 | -10(308)~10(308) |
注意,存储的均为补码,显示时转换回原码
所以**-1的存储是11111111**,转换回原码为10000001 = -1
而10000001转换回原码为11111111 = -127
另:10000000存储的为-128
00000000存储的为0