C语言数据类型的自动转换和强制转换有什么区别

C语言数据类型的自动转换和强制转换有什么区别 最好多点,详细点。

C语言数据类型转换分自动转换和强制转换两类。
自动转换
自动转换发生在不同数据类型的量混合运算时,由编译系统自动完成。自动转换遵循以下规则:
1.若参与运算量的类型不同,则先转换成同一类型,然后进行运算。
2.转换按数据长度增加的方向进行,以保证精度不降低。如int型和long型运算时,先把int量转成long型后再进行运算。
3.所有的浮点运算都是以双精度进行的,即使仅含float单精度量运算的表达式,也要先转换成double型,再作运算。
4.char型和short型参与运算时,必须先转换成int型。
5.在赋值运算中,赋值号两边量的数据类型不同时, 赋值号右边量的类型将转换为左边量的类型。 如果右边量的数据类型长度左边长时,将丢失一部分数据,这样会降低精度, 丢失的部分按四舍五入向前舍入。
强制类型转换
强制类型转换是通过类型转换运算来实现的。其一般形式为: (类型说明符) (表达式) 其功能是把表达式的运算结果强制转换成类型说明符所表示的类型。例如: (float) a 把a转换为实型(int)(x+y) 把x+y的结果转换为整型在使用。
强制转换时应注意以下问题:
1.类型说明符和表达式都必须加括号(单个变量可以不加括号),如把(int)(x+y)写成(int)x+y则成了把x转换成int型之后再与y相加了。
2.无论是强制转换或是自动转换,都只是为了本次运算的需要而对变量的数据长度进行的临时性转换,而不改变数据说明时对该变量定义的类型。

具体如下:
char short->int->usigned->long->double

float->double
温馨提示:答案为网友推荐,仅供参考
第1个回答  2013-09-22
这个还真是有点忘记了。自动转换是不是 int i=5/9; 这个算自动转换么?或则double i=1.0;等等 这些都算自动转换把int a=(int)(1.0); 这个算强制 其他就不知道了。。
第2个回答  2013-09-22
自动转化、一般都是小的转换成大的、 例如、本来是一个int类型、如果int类型和double类型进行计算、那么、得到的结果就是double类型、而你接收他的值可能是int类型在接受 例如 int a = 10 * 12.55 其中 10 *12.55 的结果会自动转换为double类型 这个时候你的int类型的 a 用来接收、就会出错、强制转换就是、 你把结果强制转换成 int 类型、但是会损失精度、(去除小数点以后的位数)称为一个整数 值得注意的是、自动转换 当中、 小的数据类型转换成大的数据类型没有错、 但是、当大的类型转换成小的类型的时候、就会出错、
相似回答