该函数应该读取一个分数并将其放在一个数组中.如果用户输入“0”,则该功能应该退出.我试图使用cin.peek()函数执行此操作,但执行总是进入if语句,并且不允许用户退出.
我应该如何正确编码呢(我愿意不使用peek(),我认为这是最简单的方法.)
谢谢!
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()有两个问题:
>此函数访问下一个字符,不会跳过前导空格.您可能希望在确定下一个字符之前跳过前导空格,例如,使用操纵符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’)
也就是说,你的程序不会检查它是否能成功读取以斜线分隔的分母和分母.你总是希望验证阅读是否成功,使用类似的东西
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; }
这样,您就可以封装斜杠测试.如果你需要在多个地方使用它,这是非常方便的.