知识点
1.显式 强制转换
int a=65;
char b = char (a);
此时b的值为字母‘a’,a的值为65。
2.隐式强制转换
int a;
float b = 2.065;
a=b;
运行完此段代码后,a的值为2。因为在赋值运算过程中,当两边的数据类型不一样时,右边的数据将强制转换为左边的数据,即float类型的b将强制转会为int类型,小数点后面的部分直接丢弃,导致精度下降。
转换方法
在C中,若参与运算的数据类型不同时,可按照一下方法进行转换。
- 转换按数据长度增加的方向进行,以保证精度不降低。如int型和longlong型运算时,先把intint量转成long型后再进行运算。
- 若两种类型的字节数不同,转换成字节数高的类型。
- 若两种类型的字节数相同,且一种有符号,一种无符号,则转换成无符号类型。
- 所有的浮点运算都是以双精度进行的,即使仅含float单精度量运算的表达式,也要先转换成double型,再作运算。
- char型和short型参与运算时,必须先转换成intint型。