C语言中的类型转换学习
在C语言中类型转换有两种:强制类型转换和隐式类型转换
强制类型转换
转换语法
(TYPE)Value
(TYPE)Value_Name
强制类型转换结果
-目标类型能够容纳目标值:结果不变
-目标类型不能容纳目标值:结果将产生截断(取低字节数据)
eg:当一个int类型的数据强制转换为short类型数据时,会取这个int数据的低两个字节。
注意
不是所有的强制类型转换都能够成功,当不能进行强制类型转换。转换时会发生错误。
代码分析
#include<stdio.h>
struct TS
{
int i;
int j;
};
struct TS ts;
int main()
{
short s = 0X1122;
char c = (char)s; //发生截断后 c = 0X22
int i = (int)s;
int j = (int)3.1415; //发生截断后j = 3,去掉小数点后面的
unsigned int p = (unsigned int)&ts;
// long l = (long)ts; //不能进行强制转换
// ts = (struct TS)l;
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;
}
在上述代码中,定义了一个char类型的变量s,并且赋值为0X1122。
1.将s这个变量强制转换为char并赋值给c,由于s占据两个字节,然而c占据一个字节。所以会发生截断,将变量s的低字节数据赋值给c;
2. 由于s占据两个字节,然而i占据4个字节,所以不会发生截断,将变量s的数据全部赋值给i;
3. 将浮点数强制转换为int整形变量时,会去掉浮点数的小数部分。保留整数部分;
4. 将一个地址变量强制转换为int整形时。如果地址是32位的,那么不会出现截断。但是如果地址是64位的,那么会出现截断。
5. 不能把一个自定义的结构体强制转换为基本long类型,所以会得到一个错误。
6. 不能把一个基本long类型强制转换为自定义的结构体,所以也会得到一个错误。
隐试类型转换
代码实例
char c = 0; //变量c占用1个字节
short s = c; //c到s隐式类型转换
int i = s; //s到i隐式类型转换
long l = i; //i到l隐式类型转换
注意
低类型到高类型的隐式类型转换是安全的,不会产生截断
高类型到低类型的隐式类型转换是不安全的,导致不正确的结果
隐式类型转换发生点
- 算术运算式中,低类型转换为高类型
- 赋值表达式中,表达式的值转换为左边变量的类型
- 函数调用时,实参转换为形参的类型
- 函数返回值,return表达式转换为返回值类型
注意
高类型与低类型的区别
所谓的高类型和低类型指的是所占内存多少字节。
安全的隐式类型转换
总结
强制类型转换由程序员负责完成
- 转换可能产生截断
- 转换不区分类型的高低
- 转换不成功时,编译器给出错误信息
隐式类型转换由编译器自动完成
- 低类型向高类型的转换是安全的
- 高类型向低类型的转换是不安全的
标准C编译器的类型检查是比较宽松的,因此隐式类型转换可能带来意外的错误。