使用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::to_int_type('/')) {
in.setstate(std::ios_base::failbit);
}
return in;
}
这样,您就可以封装斜杠测试.如果你需要在多个地方使用它,这是非常方便的.