我不想用很多复杂的定义去理解这个事情先甩代码:
#include <stdio.h>
int main() {
char a = 1;
char b = 245;
char c = a + b;
printf("%d", c);
}
结果很神奇,输出了-10。
我们用大白话从头讲起:
首先1是一个内存大小为4字节的int类型,这个1赋给了一个char类型的a,我们把a理解成一个可以装1字节的容器。很显然4大小的东西装进1字节的容器里面肯定是不够的,所以会出现溢出,溢出后截断多余位数,会从前位取1字节大小存进a里面,我们用下面的图片可以深刻理解
下面的b也是这样理解
接着我们开始做加法
因为现在相加的11110110也是char的类型一个字节,当它以%d的形式(4个字节的int类型)输出时,就会出现整数提升。
具体提升方式:将后位的空位补充为符号位
如图
解释:因为刚刚的八位二进制数中首位符号位是1(负数)所以我们把空位补充用1
注意:当我们整数提升后,首位是为1的负数,负数在电脑里面为二进制补码,所以我们转换成原码,就是.-10了。
补充:补码-1取反就得到了原码。