强制类型转换的语法:1、(Type)var_name;2、(Type)value; 强制类型转换的结果当然也就分为两种:1、目标类型能够容纳目标值,这种结果将是不变的。2、目标类型不能容纳目标值,这种的结果就是将产生截断。注意:不是所有的强制类型转换都能成功,当不能进行强制类型转换时,编译器将产生错误信息。
下来我们做个实验验证下,代码如下所示:
#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; }
根绝分析,我们得知 18、19行将出错,因为自定义类型不能转换。编译下,我们得到如下结果:
那么我们就注释掉那两行代码,再次编译,得到如下结果:
我们对照着在代码中分析的结果,从侧面验证了我们的分析是对的。
那么隐式类型转换又是怎样的呢?隐式类型转换是编译器主动进行的转换。注意:低类型到高类型的隐式类型转换是安全的,不会产生截断;高类型到低类型的隐式类型转换是不安全的,导致不正确的结果。
那么隐式类型转换都会在什么情况下发生呢?1、算数运算中,低类型转换为高类型;2、赋值表达式中,表达式的值转换为左边变量的类型;3、函数调用时,实参转换为形参的类型;4、函数返回值,return 表达式转换为返回值类型。
如下是安全的隐式类型转换:
接下来我们再次做个实验验证下,代码如下:
#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 到 i 的转换是安全的,小写字母 a 对应的 ASCII 值为97,所以打印的值为97。由 j 到 s 就是不安全的了,所以会发生截断。c 和 s 相加时,两个都会默认转换成 int 型,所以两个相加 sizeof 后大小为4。
我们在平时一定要注意隐式类型转换,因为编译器有时会自动进行隐式类型转换。强制类型转换由程序员自己负责完成,它的转换可能产生截断、转换时不区分类型的高低、转换不成功时,编译器会给出错误信息。隐式类型转换由编译器自动完成,在由低类型向高类型的转换是安全的,高类型向低类型转换是不安全的。标准 C 编译器的类型检查是比较宽松的,因此隐式类型转换可能会带来意外的错误。
有兴趣的可以加我一起学习 C 语言,QQ:243343083。
原文:http://blog.51cto.com/12810168/2095135