程序语句和表达式一般应该只使用一种类型的变量和常量,可是若是混合使用类型,函数
C使用一个规则集合来完成数据类型的自动转换。原型
如下是一些C数据类型转换的基本规则:变量
1.当出如今表达式中时,有符号和无符号的char和short类型都将自动转换为int。数据类型
2.在包含两种数据类型的任何运算中,较低级别类型将会转为运算中另外一个较高级别的数据类型。float
3.数据类型级别从高到低的顺序是long double、double、float、usigned long long、long long unsigned long、long、 unsigned int、int一个可能的例外是当long和int具备相同大小时,unsigned int级别高于long,short和char由规则1被提高到int。程序
4.在赋值语句中,计算结果将被转换为要被赋值的那个变量的类型,这个过程可能致使级别提高(被赋值的类型级别高)或者降级(被赋值的类型级别低),提高一般是一个平滑无损的过程,然而降级可能致使真正的问题。im
5.做为函数的参数被传递时,char和short会被转为int,float转为double,但能够经过函数原型的指定阻止自动提高的发生。数据
参考 : C primer plus集合