ustc oj 1002 Easy or not
来源:互联网 发布:刷论坛推广软件 编辑:程序博客网 时间:2024/06/06 08:32
这个题目还是比较有意思的
#include<cstdio>using namespace std; int main() { int c; while((c=getchar())!=EOF) { putchar(c); } return 0; }
http://blog.csdn.net/wenjun1130/article/details/2182968
while((c=getchar())!=EOF)的问题
int c;
while ( (c = getchar())!= EOF)
putchar(c);
当输入 123 CTRL+D 并按回车 之后, 我认为结果应是123并马上退出循环,
但实际并未退出,若单独输入ctrl+z则马上退出。
[/code]
原因分析:
输入缓冲是行缓冲。当从键盘上输入一串字符并按回车后,这些字符会首先被送到输入缓冲区中存储。每当按下回车键后,cin.get() 就会检测输入缓冲区中是否有了可读的数据。cin.get() 还会对键盘上是否有作为流结束标志的 Ctrl+Z 或者 Ctrl+D 键按下作出检查,其检查的方式有两种:阻塞式以及非阻塞式。
阻塞式检查方式指的是只有在回车键按下之后才对此前是否有 Ctrl+Z 组合键按下进行检查,非阻塞式样指的是按下 Ctrl+D 之后立即响应的方式。如果在按 Ctrl+D 之前已经从键盘输入了字符,则 Ctrl+D的作用就相当于回车,即把这些字符送到输入缓冲区供读取使用,此时Ctrl+D不再起流结束符的作用。如果按 Ctrl+D 之前没有任何键盘输入,则 Ctrl+D 就是流结束的信号。
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 起不到流结束的作用。
#include<stdio.h>#include<conio.h> void main(){ char c; c=getchar(); /*从键盘读入字符直到回车结束*/ //getchar()在这里它只返回你输入字符串的第一个字符,并把返回值赋值给c putchar(c); /*显示输入的第一个字符*/ printf("\n\n");}
当我输入abc的时候 按下回车 abc都进入缓冲区 getchar每次从缓冲区中读取一个字符 然后while循环逐个对它们与EOF进行比较 每比较一次就做一次输出 我们在屏幕上看着好像是abc一起输出的 实际上是分3次输出的是吗?
如果这里没有while循环 而是直接c = getchar(); putchar(c); 那么就算我输入的是abc+回车 那么getchar也只会在缓冲区中读取第一个字符 也就是a 然后putchar输出 后面的bc和回车都还在缓冲区
例如输入abc 回车后abc在它们内部的缓冲区 然后调用getchar getchar先看缓冲区内是否有数据,有就读取缓冲区理第一个数据 也就是a 然后返回这个字符的ASCII码 也就是97 然后while循环拿97和EOF(-1)比较 然后利用putchar输出 然后再次调用getchar 这次是读取b 返回值是98 然后while循环拿98和EOF比较 再putchar 这样依次下去
getchar是标准I/O函数,他们是带有缓冲区的,在这些函数的内部会使用“系统调用”来接受数据。在碰到回车时,这个函数才返回,此时你从键盘上输入的字符已经全部在它内部的缓冲区中了。注意你返回的只是一个字符,这个字符也就是你输入的第一个字符,缓冲区的第一个。然后你再次调用getchar(),它会判断缓冲区中是否已有数据,如果有数据就读取缓冲区的第一个字符,然后返回。这样依次下去,直到缓冲区为空,才会等待你输入数据。这就是为什么你输入abc会打印abc而不是
a
b
c
- ustc oj 1002 Easy or not
- 九度OJ-1448:Legal or Not
- 九度oj 题目1448:Legal or Not
- 九度OJ #1437 To Fill or Not to Fil
- 九度oj 1437 To Fill or Not to Fill
- 九度OJ题目1448:Legal or Not
- leetcode-easy OJ感想
- WOJ1340-Easy or Hard
- 【问题解决】Could not resolve host: centos.ustc.edu.cn;
- light oj An Easy LCS
- 九度OJ 1437 To Fill or Not to Fill -- 贪心算法
- 九度OJ 1437 To Fill or Not to Fill ( 贪心算法)
- 【学习笔记】〖九度OJ〗题目1437:To Fill or Not to Fill
- 九度OJ 题目1437:To Fill or Not to Fill
- 九度OJ 题目1437:To Fill or Not to Fill
- 九度OJ-浙大机试-题目1437:To Fill or Not to Fill
- 九度OJ 1437 To Fill or Not to Fill -- 贪心算法
- 九度OJ 题目1448:Legal or Not (拓扑排序)
- 安装VMware Tools Darwin
- c++和c读写文件的悲剧如何发生的
- java面试准备之---Struts2体系知识点,系统复习,struts2原理,ognl,el支持.---随时更新
- 安装错误的解决方法(mac虚拟机安装)
- C++中const用法总结
- ustc oj 1002 Easy or not
- 定制android-4.2.2开发环境
- java面试要点---Hibernate面试系统知识点复习,hibernate原理,缓冲---随时更新
- jquery.special.event-api
- 《杀戮地带4》光照技术
- java面试要点---Spring体系知识点复习,IOC,AOP---随时更新
- 网络编程
- 点点滴滴2
- 程序调试问题定位思路