我正在编写一个程序,我必须验证用户输入的值是一个有效的 float 。所以,我试过这个方法:
string test;
cin >> test;
float n;
n = atof(test.c_str());
cout << n << endl;
但它似乎并没有完成这项工作;当它进行转换时,.
之后的数字会丢失。如何验证在 C++ 中使用了有效的 float (不是 11)?
例子:
INPUT: 32.e
OUTPUT: 32 (should be error)
INPUT: 2a.1234
OUTPUT: 2 (should be error)
最佳答案
当您使用格式化读取结合检查是否读取了所有内容时,您可以确定 [complete] 值是否是有效的 float ,例如:
int main()
{
for (std::string test; std::cin >> test; ) {
std::istringstream in(test);
double value;
if (in >> value >> std::ws && in.eof()) {
std::cout << "the string '" << test << "' is a valid floating point number\n";
}
else {
std::cout << "the string '" << test << "' is not a valid floating point number\n";
}
}
}
测试会忽略字符串周围的空格。如果不需要,可以使用操纵器 std::noskipws
并且可以省略 std::ws
的使用。或者,您可以使用 strtod()
确定整个值是否表示 float 。
atof()
的作用是简单地查看其参数的初始字符串是否是有效的 float ,您引用的示例就是这种情况。
关于c++ - float 的验证和转换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20912238/