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

相关推荐
祈安_3 天前
C语言内存函数
c语言·后端
郑州光合科技余经理4 天前
代码展示:PHP搭建海外版外卖系统源码解析
java·开发语言·前端·后端·系统架构·uni-app·php
feifeigo1234 天前
matlab画图工具
开发语言·matlab
dustcell.4 天前
haproxy七层代理
java·开发语言·前端
norlan_jame4 天前
C-PHY与D-PHY差异
c语言·开发语言
多恩Stone4 天前
【C++入门扫盲1】C++ 与 Python:类型、编译器/解释器与 CPU 的关系
开发语言·c++·人工智能·python·算法·3d·aigc
QQ4022054964 天前
Python+django+vue3预制菜半成品配菜平台
开发语言·python·django
czy87874754 天前
除了结构体之外,C语言中还有哪些其他方式可以模拟C++的面向对象编程特性
c语言
遥遥江上月4 天前
Node.js + Stagehand + Python 部署
开发语言·python·node.js
m0_531237174 天前
C语言-数组练习进阶
c语言·开发语言·算法