c语言整型提升

c语言中整型算术运算总是至少以缺省整型(缺省整型(通常指int类型) :这是 C 语言中整数类型的默认基准,int的大小由编译器和系统架构决定(通常为 32 位,可存储范围约 ±21 亿),它是整型运算的 "基准精度"。)的精度来进行的

为了获得这个精度,表达式中的字符和短整型操作数在使用之前被转换为普通整型

这种转换称为整型提升

如何整型提升

1.有符号整型提升是按变量的数据类型的符号位来提升的

2.无符号位提升,高位补0

cpp 复制代码
#include <stdio.h>
int main()
{
	//运算前 ------a和b自动进行整型提升(转为int类型)
	char a = 3;//char--signed char
	//a=00000011(char只有八个比特位)
	char b = 127;//01111111=b
	//a = 3(0000 0011):符号位为 0,提升为int后,高位填充 24 个 0,结果为 0000 0000 0000 0000 0000 0000 0000 0011(十进制仍为 3)。
	//b = 127(0111 1111):符号位为 0,提升为int后,高位填充 24 个 0,结果为 0000 0000 0000 0000 0000 0000 0111 1111(十进制仍为 127)。
	//运算中 ------ 以int类型精度执行加法运算
	char c = a + b;
	//a+b=130=0000 0000 0000 0000 0000 0000 1000 0010
	//运算后 ------ 将int类型结果隐式转换为char类型(赋值给c)
	printf("%d\n", c);
	return 0;
}

整型提升是 "运算过程中" 的精度保证,运算完成后,由于要将结果赋值给char类型变量c,会发生隐式类型转换(截断转换),这一步与整型提升无关,是赋值阶段的类型适配:

  1. char仅占 8 位,因此会将 32 位int结果130低 8 位截断保留,丢弃高位的 24 个 0。
  2. 截断后得到 8 位二进制:1000 0010(这是c的存储值,占 1 字节)。
  3. 由于csigned char,存储的是补码,需要解析补码得到实际值:
    • 补码取反(所有位取反):

      补码:1111 1111 1111 1111 1111 1111 1000 0010

      取反:0000 0000 0000 0000 0000 0000 0111 1101

    • 加 1:
      0111 1101 + 1 = 0111 1110

      所以绝对值部分是 0000 0000 0000 0000 0000 0000 0111 1110

    • 加上符号位(负数):
      1 000 0000 0000 0000 0000 0000 0111 1110

      符号位是第 1 位(1 表示负),其余 31 位是 0...01111110

    • 所以最后c等于-126而不是130

相关推荐
一起养小猫4 小时前
Flutter for OpenHarmony 实战:番茄钟应用完整开发指南
开发语言·jvm·数据库·flutter·信息可视化·harmonyos
独自破碎E4 小时前
总持续时间可被 60 整除的歌曲
java·开发语言
senijusene4 小时前
数据结构与算法:队列与树形结构详细总结
开发语言·数据结构·算法
好好沉淀4 小时前
Elasticsearch 中获取返回匹配记录总数
开发语言·elasticsearch
寄存器漫游者4 小时前
数据结构:带头节点单链表
c语言·数据结构
2301_765703144 小时前
C++与自动驾驶系统
开发语言·c++·算法
定偶4 小时前
MySQL多表连接查询详解
c语言·数据库·mysql
MediaTea4 小时前
<span class=“js_title_inner“>Python:实例对象</span>
开发语言·前端·javascript·python·ecmascript
热爱编程的小刘4 小时前
Lesson04---类与对象(下篇)
开发语言·c++·算法
毕设源码-朱学姐4 小时前
【开题答辩全过程】以 基于Java的九价疫苗预约系统为例,包含答辩的问题和答案
java·开发语言