在C ++中检查整数溢出

唯一安全的方法是在溢出之前进行检查。尽管有一些检查整数溢出的方法。因此,如果您要检测无符号int加法中的溢出,则可以检查结果是否实际上小于两个相加的值。例如

示例

unsigned int x, y;
unsigned int value = x + y;
bool overflow = value < x; // Alternatively "value < y" should also work

这是因为如果x和y都是无符号整数,则如果相加并且溢出,则它们的值不能大于它们中的任何一个,因为它必须大于最大可能的无符号整数才能环绕并向前移动这些值。

另一种方法是尝试访问CPU中的溢出标志。一些编译器提供对它的访问,然后可以对其进行测试,但这不是标准的。