标题:文件结束符
只看楼主
shenjinhao
Rank: 2
等 级:论坛游民
帖 子:2
专家分:14
注 册:2011-5-20
 问题点数:0 回复次数:4 
文件结束符
文件结束符    回车 再ctrl+z 然后再来一次 也就是两次ctrll+z

它才会结束的 我以前也不明白 为什么需要两次ctrl+z才行 人们好像说是一个bug

Windows系统中一般采用阻塞式检查 Ctrl+Z、Unix/Linux系统下一般采用非阻塞式的检查 Ctrl+D。楼主是在Windows系统下,因此使用阻塞式的 Ctrl+Z 来标识流的结束。

这种阻塞式的方式有一个特点:只有按下回车之后才有可能检测在此之前是否有Ctrl+Z按下。还有一个特点就是:如果输入缓冲区中有可读的数据则不会 检测Ctrl+Z(因为有要读的数据,还不能认为到了流的末尾)。还有一点需要知道:Ctrl+Z产生的不是一个普通的ASCII码值,也就是说它产生的 不是一个字符,所以不会跟其它从键盘上输入的字符一样能够存放在输入缓冲区。明白了这几点之后就可以来解释楼主提出的问题了。

从键盘上输入abcd^z 加 回车之后在Windows系统上是这样处理的:由于回车的作用,前面的 abcd 等字符被送到输入 缓冲区(注意:上面说过了,^z不会产生字符,所以更不会存储到输入缓冲区,缓冲区中没有 ^z 的存在)。这时,cin.get() 检测 到输入缓冲区中已经有数据存在(因此不再检查是否有 ^z 的输入),于是从缓冲中读取相应的数据。如果都读取完了,则输入缓冲区重新变为空, cin.get() 等待新的输入。可见,尽管有 ^z 按下,但是由于在此之前还有其它输入字符(abcd),所以流也不会结束。

因此,输入流结束的条件就是:^z 之前不能有任何字符输入(回车除外),否则 ^z 起不到流结束的作用。




文章源自百度知道
搜索更多相关主题的帖子: Windows 缓冲区 Linux 标识 
2011-06-16 16:59
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:0 
嘿嘿,那你能告诉我,为什么VC8,VC9等等不需要回车两次?
2011-06-18 11:16
pangding
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:北京
等 级:贵宾
威 望:94
帖 子:6784
专家分:16751
注 册:2008-12-20
得分:0 
两次的哪个就是 bug。
2011-06-18 11:40
try_catch
Rank: 2
等 级:论坛游民
帖 子:32
专家分:82
注 册:2011-6-17
得分:0 
我上班的时候老板跟我提过这个问题,但我也不是特别明白
mac, linux, windows三个用的不一样,有一下三种,但是我不记得对应关系了
/r/n
/r/n/r/n
/r
应该不能算是bug吧。。

这个不是很懂。。只是说说
2011-06-21 06:24
pangding
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:北京
等 级:贵宾
威 望:94
帖 子:6784
专家分:16751
注 册:2008-12-20
得分:0 
windows 是 \r\n 或者称作 carrage-return linefeed(回车换行)是唯一一个用两个字节表示换行的系统。
unix 是 \n
mac 是 \r

C库函数遵循 unix 的古老传统,使用 \n(换行符) 做为行终止(end-of-line)标志,并在系统上执行转换任务。比如在 windows 上,以非二进制方式打开文本,读到 \r\n 时抛弃一个 \r;在写入时,遇到 \n 自动加一个 \r 之类的。


用过不只一个系统的人,普遍都对此颇有耳闻。但库函数的那个毛病必须依然认为是个 bug。
2011-06-21 07:46



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-343076-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.018660 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved