对于一个无符号类型和一个有符号类型的加法问题,参见 C++ 中有符号类型到无符号类型的转换 ,下面我们来谈谈一个无符号类型减去一个值的情形,首先看下面的代码:

1
2
3
4
5
6
7
8
9
#include <iostream>
int main()
{
unsigned i = 42, j = 10;
std::cout << "i - j = " << i - j << std::endl;
std::cout << "j - i = " << j - i << std::endl;

return 0;
}

运行结果如下:

i – j 所得到的结果很好理解,42 – 10 = 32,不多说了,那么,j – i ,即 10 – 42 为何不是 -32 ,而是 4294967264 呢?这是因为,当一个无符号类型的值减去另外一个值时,无论这个值是有符号类型还是无符号类型,其结果都不会是一个负数,而是要将得到的负数转换为对应的无符号值(参见 C++ 中有符号类型到无符号类型的转换 ),在此例中,就是要把 -32 转换为对应的无符号数值后输出,即 -32 + 4294967296 = 4294967264,符合最后程序的运行结果。

结合 C++ 中有符号类型到无符号类型的转换 ,我们可以看出,切勿混合使用带符号类型和无符号类型,因为混合使用有符号类型和无符号类型常常导致与我们期望值大相径庭的结果,因为一个表达式中同时含有无符号类型和有符号类型时,有符号类型会自动转换为无符号类型后再进行运算,这一点需要引起特别注意。