5

这可能不是错误,但我不知道出了什么问题。我的第一个条目在第二次迭代中为 str1 重复,并且从那时起是相同的方式。只有第一次迭代顺利。

#include <iostream>
#include <string>
using namespace std;

int main () {

cout << " \n Enter two words. \n " ;
char c = 'y';
string str;
string str1;
while (c == 'y'){

    getline(cin,str);

    getline (cin,str1);

    cout << " \n\n str : " << str << " str1 : " << str1 ;
    cout << " \n Continue ? \n " ;
    cin >> c;
}

return 0;
}

输出是:

输入两个字。
 你好世界
这是先生


 str : 你好世界 str1 : 这是先生
 继续 ?
 是的
你好世界


 str : str1 : 你好世界
 继续 ?
 n


4

2 回答 2

3

添加

cin.ignore( std::numeric_limits<std::streamsize>::max(), '\n' );

在你之后

cin >> c;

考虑以下输入:

    dog
    cat
    y
    owl
    fish
    n

如果我们单独检查输入流中存在的字符,我们将看到:

    d o g \n c a t \n y \n o w l \n f i s h \n n \n

第一次调用getline消费者dog\n;第二个消耗cat\n,留下这个:

    y \n o w l \n f i s h \n n \n

第一次调用cin >> c只消耗y 但不消耗后续的换行符,留下这个:

    \n o w l \n f i s h \n n \n

现在,有趣的事情开始了:在下一次调用 时会发生什么getline?当然,为什么它会读到下一个换行符。所以下一个调用getline返回一个空行,并留owl...在输入流中。

如上所述,解决方案是消耗(现在无用的)输入行的剩余部分。

于 2012-06-21T18:56:14.450 回答
1

正如罗布所说。

但是一个看起来更好的替代修复:

// change
char c = 'y';
....
while (c == 'y'){
....
    cin >> c;

// Into
std::string c = "y";
....
while (c == "y"){
....
    std::getline(cin, c);

在处理手动用户输入时,您应该小心使用 >> 运算符,因为这将始终在输入中留下 '\n'。这意味着您可以使用检索 '\n' 字符的方法 (getline()),也可以手动将其删除 (ignore())。

于 2012-06-21T22:31:34.627 回答