类型之间的转换
C语言中的数据类型可以进行转换
(1)强制类型转换
(2)隐式类型转换
1.强制类型转换
1)目标类型能够容纳目标值:结果不变
2)目标类型不能容纳目标值:结果将产生截断
注意:不是所有的强制类型转换都能成功,当不能进行强制类型转换时,编译器将产生错误信息。
实例分析
#include "stdio.h"
typedef struct
{
int i;
int j;
}NB;
int main()
{
NB nb;
short s = 0x1122;
char c = (char)s;//高位截断,剩下0x22
int i = (int)s;//结果不变,0x1122
int j = (int)3.1415;//浮点转整型,截断小数部分,剩下3
unsigned int p = (unsigned int )&nb;//结果与运行的编译器有关
//long l = (long)nb;//结构体强制转为long类型,这在C语言是不被允许的,error
//nb = (struct NB)l;//基本类型转为结构体类型也是不被允许的,error
printf("s = %x\n",s);
printf("c = %x\n",c);
printf("i = %x\n",i);
printf("j = %x\n",j);
printf("p = %x\n",p);
printf("&nb = %p\n",&nb);
return 0;
}
运行结果:
这里说一下nb,
nb的地址值强制转换位unsigned int,当前运行的编译器是32位的,将四字节的地址数据转化为四字节的类型,可以转换,不会发生截断,如果是64位的编译器,转化为unsigned int类型才会截断。
2.隐式类型转换
编译器主动运行的类型转换
(1)低类型到高类型的隐式类型转换是安全的,不会产生截断,如char→short→int→long
(2)高类型到低类型的隐式类型转换是不安全的,导致不正确的结果
隐式类型转换的发生点
1)算术运算式中,低类型转换为高类型
2)赋值表达式中,表达式的值转换为左边变量的类型
3)函数调用时,实参转换为形参的类型
4)函数返回值,return表达式转换为返回值类型
安全的转换:
实例分析
#include "stdio.h"
int main()
{
char c = 'a';
int i = c;//char-->int 可行
unsigned int j = 0x11223344;
short s = j; //unsigned int --.short 截断
printf("c = %c\n",c);
printf("i = %d\n",i);
printf("j = %x\n",j);
printf("s = %x\n",s);//高位截断
printf("sizeof(c+s) = %d\n",sizeof(c+s));
return 0;
}
运行结果如下
疑惑的是c+s最后不是3,而是4,这是为什么呢?
c+s是一个整数表达式,整数提升,他们会被转换成int来进行计算,int类型的值+int类型的值,结果还是int类型,因此sizeof(c+s)返回sizeof(int),等于4,而不是3。
如果你像下面那样写,打印出来的就分别是4,和3。
#include "stdio.h"
int main()
{
char gg=0;
short hh=0;
printf("sizeof(gg+hh) = %d\n",sizeof(hh+gg));
printf("sizeof(gg)+sizeof(hh) = %d\n",sizeof(hh)+sizeof(gg));
return 0;
}
小结
1.强制类型转换由程序员负责完成——转换可能产生截断
(1)转换不区分类型的高低
(2)转换不成功时,编译器给出错误信息
2.隐式类型转换由编译器自动完成
(1)低类型向高类型的转换是安全的
(2)高类型向低类型的转换是不安全的