C语言中怎样实现类型转换,有什么方式?
导读:这篇文章给大家分享的是C语言中实现类型转换的内容,小编觉得挺实用的,因此分享给大家做个参考,下文将介绍隐式类型转换和强制类型转换这两种方式,示例代码介绍的很详细,感兴趣的朋友接下来一起跟随小编看看吧。 类型转换 数据有不同的类型,不同...
这篇文章给大家分享的是C语言中实现类型转换的内容,小编觉得挺实用的,因此分享给大家做个参考,下文将介绍隐式类型转换和强制类型转换这两种方式,示例代码介绍的很详细,感兴趣的朋友接下来一起跟随小编看看吧。
类型转换
数据有不同的类型,不同类型数据之间进行混合运算时必然涉及到类型的转换问题。转换包括隐式类型转换和强制类型转换。
类型转换的原则:占用内存字节数少(值域小)的类型,向占用内存字节数多(值域大)的类型转换,以保证精度不降低。
隐式类型转换
隐式转换也称为自动转换,遵循一定的规则,由编译器自动完成。
C的整型算数运算总是至少以缺省整型类型的精度来进行,为了获得这个精度,表达式中的字符和短整形操作数在使用之前都被转换成普通整型,这种转换为整型提升。
整型提升:通用CPU是难以直接实现两个8比特位直接相加运算。所以表达式中各种长度可能小于int长度的整型值,都必须转换为int或者unsigned int ,然后才能送入CPU去执行运算。
代码示例1:
int main()
{
char a = 5, b = 126;
//5:00000000 00000000 00000000 00000101
//a:0000 0101(截断操作)
//126:00000000 00000000 00000000 01111110
//b:0111 1110
//当a和b相加时,都是char类型,就会发生整型提升
//int c = 000000000000000000000000 00000101 + 000000000000000000000000 01111110
//char c = 10000011(整型截断)
//以%d 打印,再次在内存中整型提升,再打印原码
//int c = 11111111111111111111111110000011(补码)
//打印原码:10000000000000000000000011111101
char c = a + b;
printf("%d\n", c);
return 0;
}
如何整型提升:按照变量的数据类型的符号位来提升。
代码示例2:
//负数的整型提升 char s1 = -1; 变量s1的二进制补码中只有8个比特位 11111111 因为char是有符号的,所以在整型提升的时候,高位补充符号位 即:11111111 11111111 11111111 11111111 //正数的整型提升 char s2 = 1; 变量s2的二进制补码中只有8个比特位 00000001 因为char是有符号的,所以在整型提升的时候,高位补充符号位 即:00000000 00000000 00000000 00000001
无符号数的整型提升,高位直接补0;
代码示例3:
隐式转换
int main()
{
int num = 5;
printf("s1=%d\n", num / 2);
printf("s2=%lf\n", num / 2.0);
return 0;
}
s1=2
s2=2.500000
请按任意键继续. . .
强制类型转换
强制类型转换指的是使用强制类型转换运算符,将一个变量或表达式转化成所需的类型
代码示例1:
#include stdio.h>
int main()
{
float x = 0;
int i = 0;
x = 3.6f;
i = x;
//x为实型, i为整型,直接赋值会有警告
i = (int)x;
//使用强制类型转换
printf("x=%f, i=%d\n", x, i);
return 0;
总结
关于C语言中实现类型转换的内容就介绍到这,上述示例具有一定的借鉴价值,感兴趣的朋友可以参考,希望能对大家有帮助,想要了解更多C语言的内容,大家可以关注其它的相关文章。
文本转载自PHP中文网
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: C语言中怎样实现类型转换,有什么方式?
本文地址: https://pptw.com/jishu/655322.html
