正在加载图片...
变量的数据类型是可以转换的。转换的方法有两种,一种是自动转换,一种是强制转换 自动转换 自动转换发生在不同数据类型的量混合运算时,由编译系统自动完成。自动转换遵循以下规则: 1.若参与运算量的类型不同,则先转换成同一类型,然后进行运算。 2.转换按数据长度增加的方向进行,以保证精度不降低。如int型和1ong型运算时,先把int量转成1ng 型后再进行运算 3.所有的浮点运算都是以双精度进行的,即使仅含 float单精度量运算的表达式,也要先转换成 double型 再作运算 4.char型和 short型参与运算时,必须先转换成int型 在赋值运算中,赋值号两边量的数据类型不同时,赋值号右边量的类型将转换为左边量的类型。如果右 边量的数据类型长度左边长时,将丢失一部分数据,这样会降低精度,丢失的部分按四舍五入向前舍入。图 21表示了类型自动转换的规则。 void main o float PI=3. 14159. int s, r=5: s=r*r*PI printf("s=d\n",s) P1<--3.14159 s<--r*kr:PI 显示程序运行结果 float Pi=3. 14159 s=r*r*PI 本例程序中,PI为实型;s,r为整型。在执行s=r*r*PI语句时,r和PI都转换成 double型计算,结果也 为 double型。但由于s为整型,故赋值结果仍为整型,舍去了小数部分 强制类型转换 强制类型转换是通过类型转换运算来实现的。其一般形式为:(类型说明符)(表达式)其功能是把表达式的 运算结果强制转换成类型说明符所表示的类型。例如:( float)a把a转换为实型(int)(x+y)把x+y的结 果转换为整型在使用强制转换时应注意以下问题 类型说明符和表达式都必须加括号(单个变量可以不加括号),如把(int)(x+y)写成(int)x+y则成了把x转 换成int型之后再与y相加了。 2.无论是强制转换或是自动转换,都只是为了本次运算的需要而对变量的数据长度进行的临时性转换,而不 改变数据说明时对该变量定义的类型。 main float f=5.75 printf("(int)f=%d, f=%f\n",(int)f, f) f<--5.75变量的数据类型是可以转换的。转换的方法有两种, 一种是自动转换,一种是强制转换。 自动转换 自动转换发生在不同数据类型的量混合运算时,由编译系统自动完成。自动转换遵循以下规则: 1.若参与运算量的类型不同,则先转换成同一类型,然后进行运算。 2.转换按数据长度增加的方向进行,以保证精度不降低。如 int 型和 long 型运算时,先把 int 量转成 long 型后再进行运算。 3.所有的浮点运算都是以双精度进行的,即使仅含 float 单精度量运算的表达式,也要先转换成 double 型, 再作运算。 4.char 型和 short 型参与运算时,必须先转换成 int 型。 5.在赋值运算中,赋值号两边量的数据类型不同时, 赋值号右边量的类型将转换为左边量的类型。 如果右 边量的数据类型长度左边长时,将丢失一部分数据,这样会降低精度, 丢失的部分按四舍五入向前舍入。图 2 1 表示了类型自动转换的规则。 void main() { float PI=3.14159; int s,r=5; s=r*r*PI; printf("s=%d\n",s); } PI<--3.14159 s<--0,r<--5 s<--r*r*PI 显示程序运行结果 float PI=3.14159; int s,r=5; s=r*r*PI; 本例程序中,PI 为实型;s,r 为整型。在执行 s=r*r*PI 语句时,r 和 PI 都转换成 double 型计算,结果也 为 double 型。但由于 s 为整型,故赋值结果仍为整型,舍去了小数部分。 强制类型转换 强制类型转换是通过类型转换运算来实现的。其一般形式为: (类型说明符) (表达式) 其功能是把表达式的 运算结果强制转换成类型说明符所表示的类型。例如: (float) a 把 a 转换为实型(int)(x+y) 把 x+y 的结 果转换为整型在使用强制转换时应注意以下问题: 1.类型说明符和表达式都必须加括号(单个变量可以不加括号),如把(int)(x+y)写成(int)x+y 则成了把 x 转 换成 int 型之后再与 y 相加了。 2.无论是强制转换或是自动转换,都只是为了本次运算的需要而对变量的数据长度进行的临时性转换,而不 改变数据说明时对该变量定义的类型。 main() { float f=5.75; printf("(int)f=%d,f=%f\n",(int)f,f); } f<--5.75
<<向上翻页向下翻页>>
©2008-现在 cucdc.com 高等教育资讯网 版权所有