我想检查在什么情况下会在C ++中生成overflow_error和underflow_error异常,因此我编写了一个演示尝试尝试生成overflow_error异常,但失败了:

#include <iostream>
#include <stdexcept>
using std::cout; using std::endl;
int main() {
    try {
        int a = std::pow(2, 31) - 1;
        cout << a << endl;
        int b = 1;
        int c = a + b;
        cout << c << endl;
    } catch (std::overflow_error ex) {
        cout << ex.what() << endl;
    }
    return 0;
}


输出是:

2147483647
-2147483648


如您所见,没有产生overflow_error异常,所以,我的问题是什么是算术溢出错误和算术下溢错误,以及如何在c ++中生成overflow_error和underflow_error异常?

最佳答案

抛出std::overflow_error的唯一标准库组件是std::bitset::to_ulongstd::bitset::to_ullong

标准库组件不抛出std::underflow_error(数学函数报告math_errhandling中指定的下溢错误)。

在您的示例中,您尝试检查有符号整数溢出。
您需要为此检查指定标志。

例如:

使用clang++编译并链接带有-fsanitize=undefined标志的程序。

% cat test.cc
int main(int argc, char **argv) {
  int k = 0x7fffffff;
  k += argc;
  return 0;
}
% clang++ -fsanitize=undefined test.cc
% ./a.out


test.cc:3:5:运行时错误:有符号整数溢出:2147483647 +1无法以'int'类型表示

关于c++ - 如何在C++中生成overflow_error或underflow_error异常?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/49356085/

10-11 21:28