让我们假设这个世界上的所有数字都是正整数,它们可以用 uintX_t C++ 类型表示。
让我们考虑下一个将 std::string 转换为数字的很棒的代码:
#include <string>
#include <cstdint>
#include <iostream>
template <typename T>
T MyAwsomeConversionFunction(const std::string& value)
{
T result = 0;
for(auto it = value.begin(); it != value.end() && std::isdigit(*it); ++it)
{
result = result * 10 + *it - '0';
}
return result;
}
int main(int argc, const char * argv[])
{
std::cout<<MyAwsomeConversionFunction<uint16_t>("1234")<<std::endl;
std::cout<<MyAwsomeConversionFunction<uint16_t>("123456")<<std::endl;
return 0;
}
如您所见,此函数中有多个错误,但我对一个特定的错误感兴趣:如何检测我的类型何时不足以包含该值(例如第二次转换调用)并在制作result = result * 10 + *it - '0';
. 我想知道该操作是否会T
在进行之前超过最大值。这可能吗?
编辑:请检查是否有符号整数溢出在 C++ 中仍然是未定义的行为?有关 C++ 中算术运算的 UB 的更多信息。我想避免result = result * 10 + *it - '0';
在结果溢出时执行该行。在答案中,该行仍在执行...
EDIT2:我在这里找到了答案:如何检测整数溢出?
EDIT3:接受的答案适用于签名类型。对于无符号类型 Cheers 和 hth。- 阿尔夫的答案是正确的。