c++ primer 5th:无符号数的转换

假设 unsinged u1 = 10, u2 = 42;
输出u1-u2是4294967264,为什么得到这个结果呢?
首先无符号数在内存中所有的bit都是表示值的,那么u1-u2 = -32,这个数在内存中的表示应该是1xxxxxxxxxx.它的值是 –2^(31) + a(a由最高位后面的二进制表示) = -32。它会被强制转换为无符号数,这是最高位的1表示不是负数了,而是2^31,从而该值变成2^31+a = -32+2^31+2^31 = 2^32 - 32 = 4294967264.所以任何一个负数转换为无符号数就是取模(该无符号数所能表示的数的个数).换句话说就是加上N*(模)使得该值回到正确的区间.

你可能感兴趣的:(c++ primer 5th:无符号数的转换)