【问题标题】:Problem with cin which does not provide correct results无法提供正确结果的 cin 问题
【发布时间】:2021-10-02 21:27:03
【问题描述】:

以下代码不是我的。它取自 Anton Spraul 的 Think Like a Programmer。这本书假装使用 cin 的方式,它可以在用户按 Enter 之前获得多个输入,它们之间有逻辑。代码如下:

#include <iostream>
using namespace std;

main()
{
    cout << "Enter a number with as many digits as you like: ";
    char digitChar = cin.get();
    int number = (digitChar - '0');
    digitChar = cin.get();
    while(digitChar != 10){
        number = number * 10 + (digitChar = '0');
        digitChar = cin.get();
    }
    cout << "Number entered: " << number << "\n";
}

您可以看到 cin.get() 被多次使用,这表明在用户输入任何数字后,即使用户没有按 Enter 键,代码也会继续运行。这对我来说没有任何意义,也不起作用(例如,如果我输入“719”,我会得到 1228 作为结果”,但我的问题是:

这段代码是否正确,问题是因为它只在某些编译器下工作而在其他编译器下不工作,或者它是否包含作者不想检查的错误?

每次本书使用 cin.get() 时,我都注意到同样的问题,显然是不正确的方式。

总结一下: 代码是否正确? 为什么会产生不正确的结果? 如果代码正确,那么 cin.get() 是如何工作的呢?

我们将不胜感激。

啊,我差点忘了:我在 Windows 10 下使用 GCC 尝试了这段代码。

【问题讨论】:

  • 您确定线路是number = number * 10 + (digitChar = '0'); 而不是number = number * 10 + (digitChar - '0');
  • 无论如何,cin.get() 实际发生的情况是,第一次调用它时,它会阻塞,直到cin 有东西要读。它不会逐个读取您输入的按键——它会等待您按 Enter 键,然后所有内容都立即对其可见。因此,对get 的第一次调用会抓取您输入的第一个字符,并将cin 中的所有剩余字符留给后续调用来抓取。
  • 还值得检查 windows 是否在换行之前发送回车,在这种情况下,它需要是 while (digitChar != 13)
  • @ChrisD 标记的好点,尽管我建议尽可能使用字符文字。所以这意味着digitChar != '\r',如果条件是while(digitChar != '\n'),原始的imo会更清楚。
  • @NathanPierson 同意了。也许这是一种教学手段,让读者想知道 10 的用途。

标签: c++ c++11 gcc cin


【解决方案1】:

我认为number = number * 10 + (digitChar = '0'); 的代码是错误的,因为这将始终将“0”的值分配给变量digitChar,您可以尝试改用number = number * 10 + (digitChar - '0');(将= 更改为减号)这将将digitChar 转换为数值并得到正确答案。

【讨论】:

    猜你喜欢
    • 2022-08-09
    • 2021-06-09
    • 1970-01-01
    • 2021-03-30
    • 2017-02-22
    • 2020-04-15
    • 2014-03-27
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多