Chinaunix

标题: 关于EOF的一个问题 [打印本页]

作者: tianjiao08    时间: 2005-12-30 14:57
标题: 关于EOF的一个问题
int c;
while ( (c = getchar())!= EOF)
    putchar(c);

我用gcc编译了该代码(cygwin), 运行,有个疑问
当输入 123 CTRL+D 并按回车 之后, 我认为结果应是123并马上退出循环,
但实际并未退出,若单独输入ctrl+d则马上退出,请教是为什么
作者: bandw    时间: 2005-12-30 16:00
你怎么输入EOF?
作者: tianjiao08    时间: 2005-12-30 16:39
ctrl+d, 是在cygwin下运行,可以理解为我是在shell中运行它

[ 本帖最后由 tianjiao08 于 2005-12-30 16:42 编辑 ]
作者: hackobe    时间: 2005-12-30 17:10
linux下,ctrl + D 是 输入 EOF 的意思。
输入 123 然后 ctrl +D 是表示 结束 123 的输入,此时 EOF 是对 “123”这个输入而言;
如果单独输入 ctrl + D 则 EOF 是对 程序而言,所以退出。
若是 123  ctrl + D ,然后在一次 ctrl + D,同样会退出程序。
以上理解如有不对之处,请指教。
作者: tianjiao08    时间: 2005-12-31 00:31
原帖由 hackobe 于 2005-12-30 17:10 发表
linux下,ctrl + D 是 输入 EOF 的意思。
输入 123 然后 ctrl +D 是表示 结束 123 的输入,此时 EOF 是对 “123”这个输入而言;
如果单独输入 ctrl + D 则 EOF 是对 程序而言,所以退出。
若是 123  ctrl + D ...


谢谢,我不明白的是,ctrl+d 代表EOF,则系统读入后,它应该跳出循环,而实际并没有跳出循环, 因此,系统并未将这个ctrl+d当成EOF,而在单独输入是,确实是当成了EOF而跳出了循环,我想知道为什么前一种未退出循环
作者: bandw    时间: 2005-12-31 08:40
帮顶

[ 本帖最后由 bandw 于 2005-12-31 08:42 编辑 ]
作者: hackobe    时间: 2005-12-31 10:28
有输入的时候 EOF 退出当前的输入,
无输入的时候 EOF 退出当前的程序。
退出也是按层次退的。
作者: rainballdh    时间: 2005-12-31 10:55
原帖由 tianjiao08 于 2005-12-30 14:57 发表
int c;
while ( (c = getchar())!= EOF)
    putchar(c);

我用gcc编译了该代码(cygwin), 运行,有个疑问
当输入 123 CTRL+D 并按回车 之后, 我认为结果应是123并马上退出循环,
但实际并未退出,若单独 ...

当输入 123 CTRL+D 并按回车 之后,OS会认为你输入的是123 CTRL+D,即(c='123 CTRL+D')!=EOF,不会推出循环。
如果你单独输入CTRL+D,(c='CTRL+D')==EOF当然就要退出
作者: tianjiao08    时间: 2005-12-31 18:24
原帖由 rainballdh 于 2005-12-31 10:55 发表

当输入 123 CTRL+D 并按回车 之后,OS会认为你输入的是123 CTRL+D,即(c='123 CTRL+D')!=EOF,不会推出循环。
如果你单独输入CTRL+D,(c='CTRL+D')==EOF当然就要退出


我觉得不是,getchar()返回的是第一个输入自符,他首先读入 1 ,输出,当缓冲非空时,继续读入,直到缓冲为空,因此,应该是他读到 ctrl+d 时并未把它当成eof,但为什么这样我就不清楚了,还请高人指教
作者: rainballdh    时间: 2005-12-31 22:08
原帖由 tianjiao08 于 2005-12-31 18:24 发表


我觉得不是,getchar()返回的是第一个输入自符,他首先读入 1 ,输出,当缓冲非空时,继续读入,直到缓冲为空,因此,应该是他读到 ctrl+d 时并未把它当成eof,但为什么这样我就不清楚了,还请高人指教

你说的对,我理解错误了
作者: rainballdh    时间: 2005-12-31 23:14
原帖由 tianjiao08 于 2005-12-31 18:24 发表


我觉得不是,getchar()返回的是第一个输入自符,他首先读入 1 ,输出,当缓冲非空时,继续读入,直到缓冲为空,因此,应该是他读到 ctrl+d 时并未把它当成eof,但为什么这样我就不清楚了,还请高人指教

你说的对,我理解错误了
作者: tianjiao08    时间: 2006-01-01 10:50
我又测试了一下,当输入 123 后,再按ctrl+d,立刻停止输入,并返回结果,实际上只读入了123,而并没有读入ctrl+d到缓冲,所以不会跳出循环,有没有哪位兄台可以解释一下ctrl+d到底起什么作用
作者: 非飞云    时间: 2006-01-01 11:39
呵呵 老大是在windows下编的程序吧?
windows下EOF是ctrl+z
作者: tianjiao08    时间: 2006-01-01 17:25
我是用cygwin, 自然是ctrl+d

[ 本帖最后由 tianjiao08 于 2006-1-1 17:28 编辑 ]
作者: rainballdh    时间: 2006-01-01 17:29
输入缓冲是行缓冲。当从键盘上输入一串字符并按回车后,这些字符会首先被送到输入缓冲区中存储。每当按下回车键后,cin.get() 就会检测输入缓冲区中是否有了可读的数据。cin.get() 还会对键盘上是否有作为流结束标志的 Ctrl+Z 或者 Ctrl+D 键按下作出检查,其检查的方式有两种:阻塞式以及非阻塞式。

阻塞式检查方式指的是只有在回车键按下之后才对此前是否有 Ctrl+Z 组合键按下进行检查,非阻塞式样指的是按下 Ctrl+D 之后立即响应的方式。如果在按 Ctrl+D 之前已经从键盘输入了字符,则 Ctrl+D的作用就相当于回车,即把这些字符送到输入缓冲区供读取使用,此时Ctrl+D不再起流结束符的作用。如果按 Ctrl+D 之前没有任何键盘输入,则 Ctrl+D 就是流结束的信号。
作者: tianjiao08    时间: 2006-01-01 19:23
受教了,不过你说的是c++的输入缓冲吧,不过两者应该差不多吧,谢谢
作者: voisky    时间: 2006-01-03 17:04
按ctrl-d只是通知tty驱动读取数据,如果没有数据驱动才认为是EOF。实际上基本没有EOF这个字符,和回车一样,也是通知tty读取数据
作者: voisky    时间: 2006-01-03 17:06
可以参考一下"apue"里面有详细的解释
作者: tianjiao08    时间: 2006-01-04 10:26
thank you
作者: tguitar    时间: 2009-05-21 16:26
这段程序在TC2.0 win2003下运行正确,输入123 Crtl+Z程序就会结束。
作者: logicBaby    时间: 2009-05-21 16:32
C-z  ?




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2