先看如下代码
int main(int argc, char const *argv[])
{
std::ostream_iterator<std::string> out_iter(std::cout, "\n");
std::istream_iterator<std::string> in_iter(std::cin), eof;
while (in_iter != eof)
{
*out_iter++ = *in_iter++;
}
}
当输入a空格符b空格符c空格符d空格符e
输出的是:
a
b
c
d
当依次输入a、b、c、d、e的时候,
结果仍然是:
a
b
c
d
原因如下:
*out_iter++ = *in_iter++;
这句的问题。
你要知道每次的读取动作发生在什么时候。
第一次 判断 in_iter != eof 时读取了 "a" ,然后在
*out_iter++ = *in_iter++;
这句完成了两件事,一是把 "a" 写到 out_iter,二是在 in_iter++ 的时候将 "b" 读入。
再次判断 in_iter != eof 时因为此时 in_iter 已经指向 "b" 了,所以不用再次读入;然后再执行到
*out_iter++ = *in_iter++;
这句把 "b" 输出到 out_iter 同时由 in_iter++ 的操作将 "c" 读入。
...
然后当 in_iter 指向 "e" 而再次执行到
*out_iter++ = *in_iter++;
这句的时候,因为将 "e" 传给 out_iter 和 in_iter++ (读入下一个字符串)这两个操作在同一个表达式中完成,所以只有输入下一个字符串后此表达式才能顺利完成动作,而此时由于正等待新的输入,所以运行实际上停在
*out_iter++ = *in_iter++; 这句话上了,也就看不到将 "f" 传给 out_iter 的执行结果。
要想看到所要的结果,只需将
*out_iter++ = *in_iter++;
这句拆成两句,明确执行顺序即可:
*out_iter++ = *in_iter;
in_iter++;
这样明确先输出再读入,就不会出现上面的情况。
实际在处理文件时由于能够判断文件结尾,不存在等待
*out_iter++ = *in_iter++;
这句执行完的情况,所以 "e" 是可以正常输出的,上面的问题只会出现在命令行输入的情况下。
本文深入解析C++中使用标准输入输出流处理命令行输入的机制,详细解释了`std::istream_iterator`和`std::ostream_iterator`的用法及如何避免在处理输入输出时的常见陷阱。
853

被折叠的 条评论
为什么被折叠?



