当前位置:C++技术网 > 资讯 > c语言学习笔记分享:1 类型转换

c语言学习笔记分享:1 类型转换

更新时间:2015-10-27 23:01:29浏览次数:1+次

隐式类型转换

整型、实型和字符型数据之间可以混合运算。例如:

      10 + ’a’ + 1.5 - 8765.1234 * ’b’

不同数据类型之间运算会进行自动类型转换,基本的转换规则如下:

自动类型转换比较简单,所以不做详细解释,只要记住上面的规则就可以。

强制类型转换

一般形式:(类型名)(表达式)

例    

(int)(x + y)
     (int)x + y
     (double)(3/2)
     (int)3.6  

说明:强制转换得到所需类型的中间变量,原变量类型、变量值保持不变

         较高类型向较低类型转换时可能发生精度损失问题

#include <stdio.h>
main()
{
   float  x; 
   int  i; 
   x=3.6;
   i=(int)x;
   printf(“x=%f,i=%d”,x,i);
}
结果:x=3.600000,i=3


类型间转换


例如


int a = 2147483648;
printf("%d",a);


这样赋值后,输出变量a的值并非预期的2147483648,而是-2147483648,原因是2147483648超出了int类型能够装载最大值,数据产生了溢出。如果换一种输出格式控制符,代码如下所示:


printf("%u",a);


输出的结果就是变量a的值,原因是%u是按照无符号整型输出的数据,而无符号整型的数据范围上限大于2147483648这个值。

当把占字节较小的数据赋值给占字节较大的数据时,可能出现以下两种情况。

第1种情况,当字节较大数是无符号数时,转换时新扩充的位被填充成0


char b = 10;
unsigned short a = b;
printf("%u",a);


这样赋值后,变量a中输出的值是10

当字节较大数是有符号数时,转换时新扩充的位被填充成符号位


char b = 255;
short a = b;
printf("%d",a);


这样赋值后,变量a输出的值是-1,变量a扩充的高8位,根据变量b的最高位1都被填充成了1,所以数值由正数变成了负数,因为变量a的最高位符号位是1,至于为什么16个1表示的是-1,涉及到二进制数的原码和补码问题,这个以后我们再谈。