我想检查在什么情况下会在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_ulong
和std::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/