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
本文详细介绍了计算机中数字的存储方式,包括原码、反码和补码的概念及相互转换过程,并列举了不同数据类型(如bool、char、int等)的取值范围,帮助读者理解计算机内部如何表示各种数值。
1434

被折叠的 条评论
为什么被折叠?



