• 混合运算时的转换:
    • 字符必须先转换为整数(C语言规定字符类型数据和整型数据之间可以通用) 。
    • short型转换为int型(同属于整型) 。
    • float型数据在运算时一律转换为双精度(double)型,以提高运算精度

  • 无符号数和有符号数之间:
  • 首先进行一个实验,分别定义一个signed int型数据和unsigned int型数据,然后进行大小比较:

    unsigned int a=20;
    signed int b=-130;
    
  • a>b?还是b>a?实验证明b>a,也就是说-130>20,为什么会出现这样的结果呢?
  • 这是因为在C语言操作中,如果遇到无符号数与有符号数之间的操作,编译器会自动转化为无符号数来进行处理,因此a=20,b=4294967166,这样比较下去当然b>a了。
  • 再举一个例子:

    unsigned int a=20;
    signed int b=-130;
    std::cout<<a+b<<std::endl;

  • 结果输出为4294967186,同样的道理,在运算之前,a=20,b被转化为4294967166,所以a+b=4294967186

  • 减法和乘法的运算结果类似。

  • 如果作为signed int型数据的b=-130,b与立即数之间操作时不影响b的类型,运算结果仍然为signed int型:

    signed int b=-130;
    std::cout<<b+30<<std::endl;
    
  • 输出为-100。