使用流失败的验证

validation using sstream failing

本文关键字:验证 失败 流失      更新时间:2023-10-16
cout << "nPlease enter x-ordinate: ";
cin >> test;
stringstream ss(test);
ss >> x;
while(ss.fail())
{
ss.str("");
cin.clear();
cin.ignore(256, 'n');  
cout << "Please enter integer: n";
cin >> test;
stringstream ss(test);
ss >> x;
cout << x << ss;    
}       
嗨,我

正在尝试通过使用 sstream 检查它是否可以转换为整数 x 来测试用户的输入是否为整数,但是一旦我输入一个有效的整数,while 循环仍然被证明是正确的,循环继续。阿诺酮能帮忙吗?

你的代码有一个小问题...您有两个名称完全不同的变量,一个用于循环条件,一个在循环主体内部。这两个变量没有任何关系或联系。

而是通过设置其字符串来重用第一个ss变量:

...
cin >> test;
ss.str(test);
...

您也不会清除循环中ss流的状态,只会清除cin,这就是循环永远不会结束的原因。

我还建议您使用流可以用作布尔条件的事实,并且operator>>函数返回对流的引用,然后您可以执行以下操作:

cout << "nPlease enter x-ordinate: ";
getline(cin, test);
istringstream ss(test);
while(!(ss >> x))
{
    ss.clear();
    cout << "Please enter integer: n";
    getline(cin, test);
    ss.str(test);
}

有关上述示例,请参阅此处。


当然,也可以直接使用cin

int x;
while (!(cin >> x))
{
    cin.clear();
    cin.ignore(numeric_limits<std::streamsize>::max(), 'n');
    cout << "Please enter integer: n";
}

有关上述示例,请参阅此处。

cin流式传输到string是没有意义的,创建一个istringstream,然后从那里流式传输到您的号码:它只是为其他类型的错误留出了空间,例如"12x"被视为12并且忽略x而不是为用户生成警告/错误消息。

您可以直接阅读以下内容:

const char* prompt = "nPlease enter x-coordinate: ";
while (cout << prompt && !(cin >> x))
{
    cin.clear();
    cin.ignore(256, 'n');  
    prompt = "Please enter integer: n";
}

如果不需要更改提示,可以直接将其放入循环中:

while (cout << "nPlease enter x-coordinate: " && !(cin >> x))
{
    cin.clear();
    cin.ignore(256, 'n');  
    std::out << "Please enter an integer.n";
}

注意:你会看到一些类似于你的第一次努力的东西,其中对string的读取使用getline而不是>>,这可能是一个很好的做法,因为它可以让你计算行号(对于解析文件比std::cin更有用)和检查值出现在其他预期数据的行上。 它看起来像这样:

std::string line;
while (std::cout << "Enter coordinate:" &&
       getline(std::cin, line))
{
    std::istringstream iss(line);
    if (iss >> x)
         break;
    std::cout << "Error - invalid coordinate, please enter an integern";
}
...use x...

测试变量是什么类型?您可以尝试将字符串作为输入的通用解析器:

template<class T>
bool tryparse(const string word, T& res)
{
   istringstream parser(word);
   bool status = (parser >> res);
   return status;
}