详解C语言基础的类型转换

编辑: admin 分类: c#语言 发布时间: 2021-12-12 来源:互联网
目录
  • 类型转换
    • 隐式类型转换
    • 强制类型转换
  • 总结

    类型转换

    数据有不同的类型,不同类型数据之间进行混合运算时必然涉及到类型的转换问题。转换包括隐式类型转换和强制类型转换。

    类型转换的原则:占用内存字节数少(值域小)的类型,向占用内存字节数多(值域大)的类型转换,以保证精度不降低。

    在这里插入图片描述

    隐式类型转换

    隐式转换也称为自动转换,遵循一定的规则,由编译器自动完成。

    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;
    

    总结

    本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注海外IDC网的更多内容!

    【文章由:韩国高防服务器 提供,感谢支持】