隐式类型转换
低精度转换成高精度
1.同种类型所占空间越大精度范围越高
long > int > short > char
2.整数类型中无符号类型精度大于有符号类型精度
unsigned > signed
3.浮点数类型精度高于整数类型精度
double > float > 整数类型
注:
1.short char int进行数据运算和数据处理时会默认转换为long类型
2.float double进行数据运算和数据处理时会默认转换为double类型
例:unsigned int a = 10;
a - 20 > 0 结果应该为真, a - 20 相当于无符号整数类型+有符号整数类型,结果会被隐式类型转换为无符号整数类型,而0是最小的无符号整数,所以a - 20 > 0 结果为真
赋值运算符
+=
-=
*=
/=
%=
例:
int a = 10; a *= 5 - 3; a的值为20;赋值运算符的优先级很低
左值:能够放在等号左边的值,可以是变量,不能是常量或表达式
右值:能够放在等号右边的值,可以为常量、变量、表达式
注:
1.整形赋值给浮点数类型扩展精度
2.浮点数类型赋值给整形舍弃精度
3.左右两边空间大小一致直接完成内存数据拷贝
4.小数据放入大空间时需要补位,有符号数补符号位,无符号数补0
5.大数据放入小空间时需要截断,截取数据低位
例:
char ch = 480;
printf("ch = %d\n", ch);
结果为ch = -32,480的二进制为1 1110 0000,char占8bit,所以在内存中保存的是1110 0000,1位符号位+7位数据位,110 0000是数据的反码形式,其原码为010 0000,故结果为-32