1

因此,我环顾四周,无法弄清楚 cin 在我的 While 循环中发生了什么。我正在阅读 C++ Primer(第 5 版)一书,我注意到在其中一个练习中,如果没有终止 while 循环,我无法使用 cin 来抓取字符串。我只使用 getline() 解决了这个问题。

当前练习的目标是要求用户输入 0 - 15 的值,并将该数字转换为“十六进制等值”(其中 0 = 1, 1 = 2, 2 = 3, ... , 10 = A,11 = B)。我尝试在没有书的情况下这样做,但失败了,但随后开始质疑书中的代码。这是书中的代码:

//Note: <iostream> and <string> have been included. using namespace std is used 
const string hexdigits = "0123456789ABCDEF";
cout << "Enter a series of numbers between 0 and 15"
     << " separated by spaces. Hit ENTER when finished: "
     << endl;
string result;
string::size_type n;

while(cin >> n)
    if (n < hexdigits.size())
        result += hexdigits[n];
cout << "Your hex number is: " << result << endl;

如果我要运行这段代码,它永远不会在不输入任何代码的情况下按回车键终止 while 循环(本质上是我认为的空格输入?)。

我来这里有两个原因:

1)为什么这段代码不起作用?2)我会很感激朝着正确的方向轻推,但不是如何让这段代码正确执行的答案

如果我不能在不妥协理由 2 的情况下接受理由 1,我宁愿让理由 1 得到满足。

快速编辑:抱歉,我使用的是 Visual Studio 2012

4

6 回答 6

3

只要您输入有效数字,它将继续读取数字。您可以通过输入不是数字的内容来终止循环,例如“再见”。在一行的开头,即在按下回车后,您还应该能够使用 Ctrl-Z 终止标准输入(我认为;我通常在类 UNIX 系统上工作,您可以使用 Ctrl- 终止标准输入D)。

true本质上,只要既没有std::ios_base::failbit也没有std::ios_base::badbit在其状态中设置流,则流转换为(您可以stream使用 来查看 的状态stream.rdstate())。只要您成功地从流中读取整数,它就没有理由进入失败状态。当您输入不是整数的内容时,它将被std::ios_base::failbit设置。同样,当它到达流的末尾时。

于 2013-10-10T23:47:41.063 回答
1

@Protomega,您可以使用相同的代码,但按 Ctrl+D 停止输入流。

于 2013-10-11T01:03:16.353 回答
0

根据您的平台,按 Enter 会产生 CR 或 LF 或两者。这是一个有效的输入,因此满足继续 while 循环的条件。您需要在输入开始时明确测试这些字符,或者使用 Ctrl-C 跳出循环。

作为可读性问题,我会在循环中需要的代码周围包含大括号。您所拥有的是有效的 C++,因为没有大括号,while将在下一条语句上循环,而整个if条件是一条语句。即使在单行循环中也可以练习将它们放入,这样您将来会省去一些令人头疼的调试。

于 2013-10-10T23:46:10.387 回答
0

有一种更简单的方法可以做到这一点:

const string hexdigits = "0123456789ABCDEF";
cout << "Enter a series of numbers between 0 and 15 separated by spaces. Hit ENTER when finished: " << endl;
string line;
string result;
if (getline(cin, line)) // get the whole line
{
    istringstream iss(result); // break them by spaces
    int i;
    while (iss >> i)
    {
        result += hexdigits[i];
        result += " ";
    }
    cout << "Your hex result:  " << result << endl;
}
else
{
    cout << "Error handling input!" << endl;
}

使用您的解决方案,您需要按 Ctrl-D 来结束输入。

于 2013-10-11T00:12:48.960 回答
0

CTRL-D 适用于 Linux。一个更简单的代码片段如下:

vector<double> vd;
for (double d; cin>> d;)
     vd.push_back(d);
for(int i=0; i<vd.size(); ++i)
   cout << vd[i] << endl;
于 2017-08-18T18:56:01.327 回答
0

分别将 While() 视为一个循环,while (cin >> n)以及括号内的内容。当 Loop 开始时,您将被移到括号中,并要求您输入 cin 的内容。每次循环开始时都会发生这种情况。在这种情况下,无法终止循环。这和我说的一样:

while (/*some condition*/) {
cin >> n; // this is always valid, true
}
于 2021-04-24T12:05:11.333 回答