1.整型变量在内存中以二进制补码的形式存储。根据存储空间的不同,C语言将整型变量分为三大类:基本整型、短整型和长整型。根据有无符号位,整型数据又可分为有符号和无符号两种类型。
如下图所示
整型变量在赋值时会有一定的范围限制,对于不同的赋值,会因为数据溢出使得输入值与实际得到的值发生偏差。
(出现数据溢出的原因是!!每种变量都有固定的存储长度,由于存储空间是有限的,因此每种变量的取值范围也是有限的)【了解即可】
2.int型数据溢出
int型存储空间为2个字节,即2的16次方(65536)个数码。在65536个整数中又分为正整数、0和负整数。正整数1~32767,负整数-32768~-1。假设你输入的值为x,实际得到的值为y。
(1)32767<x<65536时,y=x-65536
(2)-65536<=x<-32767,y=+65536
(3)大于65536减去65536,小于-32767加上65536
3.unsigned int
其允许的取值范围是0~65535.x>65535,y=x%65535;x>-65535,y=x+65536.
4.对整型变量赋以小数是,只保留整数部分,小数部分被直接舍弃,不做四舍五入处理。