该函数应该读取一个分数并将其放入数组中。如果用户输入“0”,该函数应该退出。我尝试使用 cin.peek() 函数来执行此操作,但执行始终进入 if 语句并且不允许用户退出。
我应该如何正确编码(我愿意不使用 peek(),我认为这是最简单的方法。)
Thanks!
void enterFrac(Fraction* fracs[], int& index)
{
int n, d;
char c, slash;
cout << "Enter fractions (end by entering a 0): ";
c = cin.peek();
if ( c != '0')
{
cin >> n >> slash >> d;
Fraction* f = new Fraction();
f->num = n;
f->den = d;
fracs[index] = f;
index++;
}
}
然而 peek() 的这个测试是有效的:
#include <iostream>
using namespace std;
int main () {
char c;
int n;
char str[256];
cout << "Enter a number or a word: ";
c=cin.peek();
if ( (c >= '0') && (c <= '9') )
{
cin >> n;
cout << "You have entered number " << n << endl;
}
else
{
cin >> str;
cout << " You have entered word " << str << endl;
}
return 0;
}
您的使用有两个问题std::istream::peek()
:
- 该函数访问下一个字符并执行not跳过前导空格。您可能想在确定下一个字符是什么之前跳过前导空格,例如使用操纵器
std::ws
: (std::cin >> std::ws).peek()
.
- 结果来自
std::istream::peek()
不是一个char
。相反,它是一个std::char_traits<char>::int_type
(这是一个奇特的拼写int
)。结果可能是,例如std::char_traits<char>::eof()
如果'0'
碰巧是负面的(我不知道它在哪里的任何平台;但是,例如,我名字中的有趣角色'ü'
在平台上是负值char
已签名)您也不会得到正确的结果。也就是说,您通常比较的结果std::istream::peek()
反对的结果std::char_traits<char>::to_int_type()
,也就是说,你会使用这样的东西:std::cin.peek() == std::char_traits<char>::to_int_type('0')
也就是说,您的程序不会检查是否可以成功读取由斜杠分隔的分子和分母。你always想要验证读取是否成功,例如,使用类似
if ((std::cin >> nominator >> slash >> denominator) && slash == '/') {
...
}
只是为了娱乐,您可以创建一个操纵器来测试字符是否是斜杠,实际上:
std::istream& slash(std::istream& in) {
if ((in >> std::ws).peek() != std::char_traits<char>::to_int_type('/')) {
in.setstate(std::ios_base::failbit);
}
return in;
}
这样,您就可以封装斜杠测试。如果您需要在多个地方使用它,这非常方便。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)