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

相关推荐
秋94 小时前
Go语言(Golang)开发工程师全景解析:岗位职责·语言优势与使用场景·各城市薪资·发展前景·高考志愿填报(2026版)
开发语言·golang·高考
十月的皮皮5 小时前
C语言学习笔记20260606- 求月份天数三种写法
c语言·笔记·学习
huangdong_5 小时前
1688商品图片采集技术解析:登录态处理与SKU图自动分类
开发语言
chase_my_dream5 小时前
C++ + SLAM 高频面试问题整理
开发语言·c++·面试
Cloud_Shy6185 小时前
解读《Effective Python 3rd Edition》:从练气到老魔(第五章 Item 30 - 32)
开发语言·人工智能·笔记·python·学习方法
caimouse5 小时前
Reactos 第 5 章 进程与线程 — 5.8 Windows 的 APC 机制
c语言·windows
天佑木枫6 小时前
15天Python入门系列 · 序
开发语言·python
宋拾壹7 小时前
同时添加多个类目
android·开发语言·javascript
凡人叶枫7 小时前
Effective C++ 条款04:确定对象被使用前已先被初始化
java·linux·开发语言·c++·嵌入式开发
小小龙学IT8 小时前
Go 语言后端开发:从并发模型到生产落地的工程实践
开发语言·后端·golang