C语言中的数据类型可以进行转换
强制类型转换的语法
强制类型转换的结果
注意:不是所有的强制类型转换都能成功,当不能进行强制类型转换时,编译器将产生错误信息(比如将自定义数据类型转换成基本数据类型)。
下面看一段强制类型转换的代码:
#include <stdio.h> struct TS { int i; int j; }; struct TS ts; int main() { short s = 0x1122; char c = (char)s; // 0x22 int i = (int)s; // 0x00001122 int j = (int)3.1415; // 3 unsigned int p = (unsigned int)&ts; //long l = (long)ts; // error //ts = (struct TS)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("&ts = %p\n", &ts); return 0; }
下面为输出结果:
注意将自定义数据类型转换成基本数据类型会报错。
隐式类型转换是编译器主动进行的类型转换
注意:
低类型到高类型的隐式类型转换是安全的,不会产生截断
高类型到低类型的隐式类型转换是不安全的,导致不正确的结果
隐式类型转换的发生点
安全的隐式类型转换:
下面看一段隐式类型转换的代码:
#include <stdio.h> int main() { char c = 'a'; int i = c; // safe unsigned int j = 0x11223344; short s = j; // unsafe 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 为 char 类型,s 为 short 类型,再进行四则运算前,各个比 int 窄的加数自动提升为 int,结果也为 int 类型,故 size 为4
强制类型转换由程序员负责完成
隐式类型转换由编译器自动完成
标准C编译器的类型检查是比较宽松的,因此隐式类型转换可能带来意外的错误。