【发布时间】: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 的用途。