再看以下一段代码:
  int main()
  {
  unsigned char ch = 255;
  ch += 1;
  printf("%d ", ch);
  return 0;
  }
  输出结果为:0;
  其分析为:首先ch = 255提升为整形,在计算机的存储为:(000....)11111111,然后(000....)11111111+1 = (000...)0001 00000000;然后再将后的八位二进制截取给ch,由于后八位全是0,因此ch = 0了。
  同理:对于遇到整形int short, long等出现上述情况时,我们也可以这样分析得到结果。
  类型转换
  1、将实型数据(包含单、双精度)赋值给整型变量时,舍弃实数的小数部分。
  2、将整型数据赋值给单双精度变量时,数值不变,但以浮点数形式存储到变量中
  3、将一个double型数据赋值给float数据时,截取其前面7位有效数字,存放到float变量的存储单元(32位)中。但应注意数值范围不能溢出
  将一个float数据赋值给double变量时,数值不变,有效位数扩展到16位,在内存中以64位存储
  4、字符型数据赋值给整型变量时,由于字符只占一个字节,而整型变量为2个字节,因此将字符数据(8位)放到整型变量的低8位中。有两种情况:
  (1)如果所用系统将字符处理为无符号的量或是对unsigned char型变量赋值,则将字符的低8位放到整型变量的低8位,高8位补零。
  (2)如果所用系统将字符处理为有符号的(signed char),若字符高位为0,则整型变量高8位补零;若字符高位为1,则高8位全补1.这称为符号扩展。
  5、将一个int、short、long型数据赋值给一个char型变量时,只将其低8位原封不动地送到char型变量
  将一个long型数据付给一个int型变量时,只将long型数据中的低16位原封不动地送到整型变量,这称为“截断”
  6、将unsigned int型数据赋值给long int型变量时,不存在符号扩展问题,只需将高位补0即可