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类型的,要向上转换

相关推荐
San30.10 分钟前
深入 JavaScript 内存机制:从栈与堆到闭包的底层原理
开发语言·javascript·udp
灰灰勇闯IT30 分钟前
RN路由与状态管理:打造多页面应用
开发语言·学习·rn路由状态
wd_cloud30 分钟前
QT/6.7.2/Creator编译Windows64 MySQL驱动
开发语言·qt·mysql
亭上秋和景清34 分钟前
指针进阶:函数指针详解
开发语言·c++·算法
胡萝卜3.035 分钟前
C++现代模板编程核心技术精解:从类型分类、引用折叠、完美转发的内在原理,到可变模板参数的基本语法、包扩展机制及emplace接口的底层实现
开发语言·c++·人工智能·机器学习·完美转发·引用折叠·可变模板参数
9ilk36 分钟前
【C++】--- C++11
开发语言·c++·笔记·后端
biter down1 小时前
C++ 函数重载:从概念到编译原理
开发语言·c++
yue0082 小时前
C# winform自定义控件
开发语言·c#
无限进步_3 小时前
深入理解 C/C++ 内存管理:从内存布局到动态分配
c语言·c++·windows·git·算法·github·visual studio
JANGHIGH3 小时前
c++ 多线程(三)
开发语言·c++