我正在用 C++ 编写一个程序,该程序应该根据用户输入计算算术结果。如果用户输入一个 int
double
和 float
无法处理的巨大值,我想非常仔细地处理它,然后我抛出溢出异常数据。我该如何处理这些类型的异常。
第二部分是如果用户给我两个数字,经过乘法或加法后,得到的数字可能比特定数据类型的范围大很多,我们如何处理这种类型的异常?
最佳答案
在进行算术运算之前,您可以使用 numeric_limits
进行一些检查。
例如一个添加两个 int
的函数。你可以做类似的事情:
int AddInt(int a, int b)
{
if (a>0 && b>0)
{
// May overflow
if (a > std::numeric_limits<int>::max() - b)
{
// Will overflow
throw ....something....
}
}
else if (a<0 && b<0)
{
// May overflow
if (a < std::numeric_limits<int>::min() + b)
{
// Will overflow
throw ....something....
}
}
// We are good - no overflow
return a+b;
}
关于c++ - 当数字可能溢出C++中特定数据类型的范围时如何处理异常?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43534686/