学习C语言至今,已经学习了很多的数据类型了,一般常用的为有符合类型以及无符号类型的数据,一般包括 char、short、int、float、double、long、long long等C语言的内置类型,然而学习了这么多的数据类型,我们可能对数据在内存中是怎样存储的认识是非常的模糊,一般而言在内存中数据的存储方式一般按照补码的方式进行存储,而规定正数的原码与补码相同,负数的原码要经过原码取反,得到反码,在反码加1得到补码,其原因是因为使用补码可以将符号位和数值域统一处理; 同时加法和减法也可以统一处理(CPU只有加法器)此外,补码与原码相互转换,其运算过程是相同的,不需要额外的硬件电路。如图一所示内存中对数据的存储及运算的过程。
然后就是当在使用的额数据类型比int型数据较小时,如char 、short等数据类型时,由于这些数据比int小,所以在进行数据的运算时,会将较小的数据进行整形的提升,使参与运算的数据的大小相等,在进行运算,以确保运算的结果不会出错,其过程如图2所示。
3、到现在为止我们知道了数据在内存中都是以补码的形式进行存储的,而通过下面这道题我们来探究char类型的数据在内存中的存储是怎样分布的。