目录
1.表达式求值
2.隐式类型转换
2.1 (整型提升)
- 首先,3是一个整数,占32位比特的内存空间 ,3的补码是下面这个。但是类型是char一个字节,所以按规定取低八位放到char a里面(a-0000 0011)
- 127也是一个整数,占32位比特的内存空间 ,127的补码是下面这个。但是类型是char一个字节,所以按规定取低八位放到char b里面(b-0111 1111)
- 然后a和b如何相加呢,由于他们自身的大小没有达到整型的大小,要整型提升
- 整型提升:按照变量类型的符号位提升。有符号数按照符号位补齐,无符号数按0提升
- 3(0000 0011)高位是0,前面补齐0,达到32位。b也一样。所以相加的结果为
- 结果放到c里,但是c是char类型,再次进行截断,取低八位(c-1000 0010)
- 最后打印,打印时%d,整数形式,又要整型提升。c(1000 0010)最高位是1,前面补齐1,达到32位
- 打印的是原码,原码:-126
- 整型提升的意义:
- 字符char、短整型short都要整型提升
2.1.1 练习
- 首先判断相等也有整型提升
- 0xb6是1011 0110,按照符号位,补齐1,所以判断式不相等
- b也是如此
- c本身就是整型,不需要提升,所以相等,打印c
2.1.2 练习
- 第一个就是char一个字节
- 第二个+c发生运算,产生整型提升,占四个字节
- 第三个不会整型提升,所以也是char一个字节
2.2 算术转换
- 整型提升针对于那些大小是(<整型)的
- 对于剩下(>=整型)的,有算术转换 :会把下面小的类型转化成上面大的一样的类型然后运算
3.操作符的属性
- 顺序:由高到低
- 是否控制顺序:除了结果就不在运算其他的。(逗号表达式:从左到右运算,但真正起到作用的只有最后一个表达式)
- 有问题的代码:
![]()