既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
printf("c=%d\n", c);
printf("d= %d", d);
return 0;
}
 运行结果:
c= -124
d= 132
原因分析:
//char a=5
//0000 0101 – a=5
//char b=127
//0111 1111 – b=127
因为参与了运算,并且char类型小于int型的精度,所以要进行整形提升.
整形提升后:

结果1:将结果放入char类型的变量c中,c只能存储八位
所以只保留了结果的后面八位数据即

char类型是有正负的,所以最高位为符号位,计算结果在内存中是补码的形式,我们要转化为原码.

原码的值是-124
结果2:
运算的时候经过整形提升为整形再运算,所以当结果存放在d里面的时候,直接就可以算出132.

### 示例 2:
补充知识:
由于我们习惯性使用十进制,当我们在定义一个整形变量a的值为10的时候习惯性写为:
int a=10;
其实也可以用其他进制表示也是一样的,例如:用16进制表示
int a=0xa;
这两种是等价的,ox是16进制的前导符,千万别把它当做数据哈.
#include <stdio.h>
int main()
{
char a = 0xa1;
short b = 0xb111;
int c = 0xc1111111;
if (a == 0xa1)
printf(“a”);
if (b == 0xb111)
printf(“b”);
if (c == 0xc1111111)
printf(“c”);
return 0;
}
试着猜一下运行的结果:

运行结果;
c
原因分析:
没错,又是整形提升在搞怪,它又偷偷将你的数据类型改了
a== 0xa1
整形提升前:1010 0001-----值为 161
整形提升后:1111 1111 1111 1111 1111 1111 1010 0001 ----是一个负数的补码,需要转化为原码
b
整形提升前:1011 0001 0001 0001 —值为45329
整形提升后:1111 1111 1111 1111 1011 0001 0001 0001 ----是一个负数的补码,需要转化为原码
c
1100 0001 0001 0001 0001 0001 0001 0001
整形提升之后,值肯定不一样了,所以只有没有发生整形提升的c被打印了出来.
### 示例3:
补充知识:
%u是按无符号整形(unsigned int)打印
猜一猜,结果吧
#include <stdio.h>
int main()
{
char crow = 1;
printf(“%u\n”, sizeof(crow));
printf(“%u\n”, sizeof(+crow));
printf(“%u\n”, sizeof(-crow));
return 0;
}

运行结果:
1
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!**
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新