c语言中的整形提升和算数转换

整形提升:

表达式中字符和短整型操作数在使用之前转换为普通整形

分为两种:

有符号整形 提升:按照变量的数据类型的符号位来提升

无符号整形 提升:按照高位补0的方式及进行提升

例如:char a=20;char b=130;char c=a+b;求出c的值

20的二进制编码为://00000000000000000000000000010100

因为char占一个字节,所以采用截取的方式保留8位:

所以在char中20的二进制编码为://00010100

同理130为://10000010

进行相加时:如以上方式按照符号位进行提升(char是否是signed char取决于编译器)

所以20对应//00000000000000000000000000010100

130对应//11111111111111111111111110000010

按位进行相加加完后是//11111111111111111111111110010110 这是补码的形式

求出原码,符号位不变取反加一://1000000000000000000000001101010

c在char中所以截取8位为://01101010 为106,所以c的值为-106

算数转换:

讨论的是类型大于整形的的实现

向上转换:1:long double

2:double

3:float

4:unsigned long int

5:long int

6:unsigned int

7:int

例如:int a=10;float c=20;则z+c就是float类型的,要向上转换

相关推荐
小小码农Come on4 分钟前
QT开发环境安装
开发语言·qt
云深处@7 分钟前
【C++】哈希表
开发语言·c++
weixin_4521595510 分钟前
模板编译期条件分支
开发语言·c++·算法
guygg8810 分钟前
傅立叶光学的Matlab实现方法
开发语言·matlab
时时三省12 分钟前
【时时三省】(C语言基础)共用体/联合体
c语言
码农六六13 分钟前
js函数柯里化
开发语言·前端·javascript
2501_9411481514 分钟前
C++ map / multimap 保姆级教程
java·开发语言·c++
ʚB҉L҉A҉C҉K҉.҉基҉德҉^҉大23 分钟前
C++中的策略模式进阶
开发语言·c++·算法
xb113229 分钟前
C#串口通信
开发语言·c#
小小码农Come on29 分钟前
QT内存管理
开发语言·qt