欢迎来到博主的专栏C语言进阶指南。
博主id:reverie_ly
显式转换
我们可以将某个表达式强制转换成其他类型。
代码语言:c复制int i = 25555;
i = (unsigned char)i;
此时表达式中的i被转换unsigned char类型,数值是211
隐形转换
我们前面已经了解了浮点数和整数的存储形式是完全不一样的,但是在C语言中是可以用int类型的数据接收到float类型的数据的(会发生精度丢失)
代码语言:c复制float f=3.14
int i=f;//i的值是3
这是因为C语言会对不同的类型进行隐性转换。隐型转换的原因是因为计算机的特性决定的(博主一知半解就不聊了-- )。
隐形转换的规则如下:
1)参与表达式的变量类型与优先级最高的变量类型一致
比如:
代码语言:c复制int i;
long l;
unsigned int ui;
i l ui;
上式中整型i和无符号整型ui会被隐形转换成long类型(因为long类型的数据占用8字节,高于其他两位)
C语言中隐形转换的优先级如下:
1、如果整数类型与浮点型进行算术运算,那么整数类型总是转换成浮点型
2、如果整数类型占用的字节相同,那么有符号整型总是转换成无符号整型参与计算
代码语言:c复制int i=-10;
unsigned int ui=10;
if (ui > i)
printf("ui>i");
else
printf("ui<i");
如果i是有符号整型,那么这个表达式是真的,但是实际上这个判断表达式是0(false)。结果是打印ui<i.
3、如果操作数的类型不一致,那么占用内存低的会被隐形转换为操作数中占用内存高的数据类型
浮点数数据的类型大小为:long double>double>float
整数数据的类型大小为:long long int>long int>int>short int>char.
2)表达式的结果类型与赋值操作的左值一致
无论左值的类型是什么,表达式的结果总会被转换成与左值一致的类型
代码语言:c复制 int i = 25555;
char ch = -1;
ch = i ch;
ch的结果为-46.没有被隐形转换
注意隐形转换在表达式结束后就会消失,不会说变量a在表达式中隐形转换成long类型之后就是long类型的变量。
不足缺省整型(int)的整数类型参与计算时总是会被隐形提升为int类型。这种类型有:short,unsigned short,char,unsigned char。这些类型在参与算术计算时,如果没有被隐式转换成int及int类型以上的类型,那么都会被转换成int类型。
整型提升
一个8位的数据(char或unsigned char),如何转换成一个32位的数据(int 或unsigned int)呢?
当发生这种位数的扩大时,发生的便是整型提升。整型提升的方法如下:
如果是有符号整型:根据符号位的位数来提升,如果从32位提升至64位整数,如果int型的符号位为1,整型提升的过程就是在最高位补1.比如-1的存储位数为
11111111 11111111 11111111 11111111
整型提升后
(11111111 11111111 11111111 11111111) 11111111 11111111 11111111 11111111
括号中是被提升的位数
如果是无符号整型,那么提升的过程就只在最高位补0.
数据截断
数据不仅能转换成更高位,还能转换成更低位。
代码语言:c复制int i=2555;
unsigned char ch=i;//i被转换成char类型
截断的方法如下:只保留后面符合转换类型的数位。比如上面的i的内存储存是
00000000 00000000 00001001 11111011
截断后只剩下符合unsigned char类型的后八个数位,即
11111011
ch的值为251。
注意无论是截断还提升都是只发生在表达式中的。并不会把i的实际数据类型变换,在这个表达式过后i还是int类型