iostream输入输出流互相绑定问题

本文深入解析C++中使用标准输入输出流处理命令行输入的机制,详细解释了`std::istream_iterator`和`std::ostream_iterator`的用法及如何避免在处理输入输出时的常见陷阱。

先看如下代码

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" 是可以正常输出的,上面的问题只会出现在命令行输入的情况下。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值