C语言中的数据类型可以进行转换
- 强制类型转换
- 隐式类型转换
long l = 100;
int i = (int)l; // 强制类型转换
short s = 100;
int i = s; // 隐式类型转换
强制类型转换
语法
(Type)var_name
(Type)value
强制类型转换结果
- 目标类型能够容纳目标值:结果不变
- 目标类型不能容纳目标值:结果产生截断
注意:
不是所有的强制类型转换都能成功,当不能成功时,编译器将产生错误信息
struct TS
{
int i;
int j;
};
int main()
{
struct TS ts = {0, 0};
struct TS tt = {1, 1};
struct TS* ta = &tt;
int* ptr = NULL;
int a = 10;
ptr = &a;
short s = 0x1122;
char c = (char)s; // 22
int i = (int)s;
int j = (int)3.1415;
unsigned int p = (unsigned int)&ts;
//long l = (long)ts;
//ts = (struct TS)1;
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);
printf("ptr = %p\n", ptr);
printf("a = %p\n", &a);
printf("a = 0x%x\n", &a);
printf("&tt = %p\n", &tt);
return 0;
}
输出:
s = 1122
c = 22
i = 1122
j = 3
p = cbeb6ce0
&ts = 0x7ffdcbeb6ce0
ptr = 0x7ffdcbeb6cd0
a = 0x7ffdcbeb6cd0
a = 0xcbeb6cd0 // 64位机器下格式符 %x产生截断
&tt = 0x7ffdcbeb6cf0
struct TS
{
int i;
int j;
};
struct TS ts;
long l = (long)ts;
自定义的结构体类型是不能转换为基本类型,基本类型也不能转化为结构体类型
unsigned int p = (unsigned int)&ts;
和计算机有关系32或64位(还和安装的是的软件是32位的还是64位的)
如果是64位的机器那ts的地址是8个字节的强制转换成4个字节的会报错的
隐式类型转换
编译器主动进行类型转换
char c = 0;
short s = c; // 隐式类型转换
int i = s; // 隐式类型转换
long l = i; // 隐式类型转换
注意:
低类型到高类型的隐式类型转换是安全的,不会产生截断
高类型到低类型的隐式类型转换是不安全的,导致不正确的结果
隐式类型转换的发生点
- 算术运算式中,低类型转换为高类型
- 赋值表达式中,表达式的值转换为左边变量的类型
- 函数调用时,实参转换为形参的类型
- 函数返回值,return表达式转换为返回
Char 和short属于低类型 需要转化为高类型
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 = a
i = 97
j = 11223344
s = 3344
sizeof(c + s) = 4 // 隐式类型转换为 int
小结
强制转化有程序员负责完成
- 转换可能产生截断(高位舍弃,浮点数转换成整形的会舍弃小数部分)
- 不区分类型的高低;
- 转化不成功时编译器会给出错位信息;
隐形类型的转化由编译器自动完成:
- 低到高是安全的
- 高到低转化是不安全的