众所周知,数据的类型一般有整形、字符型、浮点型这几种类型,而想要充分理解代码的运行,还需要理解数据在内存中存储,就先理解我们经常使用的整型类型的存储方式。
首先,我们知道了变量分配四个字节的空间,那么是如何储存的呢,
int a = 10;
int b = -10;
原码、反码、补码
计算机是使用这三种来表示二进制存储的,而三种存储方式都被分为两部分,分别为
符号位和
数值位两部分,符号位中用
1表示
负,用
0表示
正。
正数的原、反、补码都相同。
负整数的三种表示方法各不相同。
原码
符号位表示正负,直接将数字转换为二进制
int a = 10;
// 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 0 原码
反码
将原码的符号位不变,其他位依次按位取反就可以得到反码。
//0 1 1 1 1 1 1 1 1 1 1 1 1 0 0 1 补码
补码
反码+1就可以得到补码
//0 1 1 1 1 1 1 1 1 1 1 1 1 0 1 0
在计算机当中,整型存放的就是它的补码,而加减法也是补码之间的加减法。
数值一律用补码来表示和存储。原因在于,使用补码,可以将符号位和数值域统一处理。
进行加法和减法也可以统一处理(
CPU只有加法器)此外,补码与原码相互转换,其运算过程是相同的,不需要额外的硬件电路。