一、表达式求值
- 在我们平常的表达式求值的题目中,虽然看似是道很简单的题目;但是出题人总是会埋坑,其中最常见的就是整型提升与算术转换。
二、整型提升
- C语⾔中整型算术运算总是⾄少以缺省(默认)整型(int)类型的精度来进⾏的;为了获得这个精度,表达式中的字符和短整型操作数在使⽤之前被转换为普通整型,这种转换称为整型提升。
- 用我们平常人能听懂的话来讲,就是整型算术运算的时候,像char类型,short类型,反正就是类型所占字节的大小小于int类型的,通常会先转换为int类型,进行运算。
- 整型提升的意义:(看不懂拉到,会用就行,反正我看不懂)
- 表达式的整型运算要在CPU的相应运算器件内执⾏,CPU内整型运算器(ALU)的操作数的字节⻓度⼀般就是int的字节⻓度,同时也是CPU的通⽤寄存器的⻓度。因此,即使两个char类型的相加,在CPU执⾏时实际上也要先转换为CPU内整型操作数的准⻓度。
- 通⽤CPU(general-purposeCPU)是难以直接实现两个8⽐特字节直接相加运算(虽然机器指令中可能有这种字节相加指令)。所以,表达式中各种⻓度可能⼩于int⻓度的整型值,都必须先转换为int或unsigned int,然后才能送⼊CPU去执⾏运算。
- 如何进行整型提升:有符号的整数根据变量的数据类型的符号位数字来提升(如负数整型,高位补1,正数类型,高位补0);无符号的整数提,整型提升补0。
三、算术转换
- 若操作符的左右两个数据的类型不是同一类型,则会按照某个数据的类型,对另一个数据类型进行转换。下面的层次体系称为寻常算术转换。
- 如果某个操作数的类型在上⾯这个列表中排名靠后,那么⾸先要转换为另外⼀个操作数的类型后执⾏运算。
- 当类型是char类型或short类型的时候,则会先进行整型提升,后进行算术转换。