c整型中的运算总是至少以缺省整型类型的精度来进行的,所以当字符型或者短整型在进行运算时为了获得这个精度,先要提升成普通整型,再运算。

例:

  char a=127;

  char b=1;

  char ret=a+b;


在进行运算时,先进行“整型提升”(提升成×××):

char类型的127 是:0111 1111

进行整型提升后是:00000000 00000000 00000000 01111111


char类型的1 是:0000 0001

整型提升后是:00000000 00000000 00000000 00000001


提升后在进行运算:

              00000000 00000000 00000000 01111111

              00000000 00000000 00000000 00000001

         结果 00000000 00000000 00000000 10000000

然后再发生截断:ret=1000 0000

在这个例子中计算的结果与算术结果没有区别,但是入股在下面这个例子中区别就大了:

ret=((a<<2)+b)>>2,

如果不进行整型提升,则当移位是会将高位丢失。