getchar

getchar函数每次只从缓冲区中接受一个字符。编程

 

getchar有一个int型的返回值。缓存

当程序调用getchar时,程序就等着用户按键,用户输入的字符被存放在键盘缓冲区中,直到用户按回车为止(回车字符也放在缓冲区中)。当用户键入回车以后,getchar才开始从stdin流中每次读入一个字符,getchar函数的返回值是用户输入的第一个字符的ASCⅡ码,如出错返回-1,且将用户输入的字符回显到屏幕。函数

 

如用户在按回车以前输入了不止一个字符,其余字符会保留在键盘缓存区中,等待后续getchar调用读取。也就是说,后续的getchar调用不会等待用户按键,而直接读取缓冲区中的字符,直到缓冲区中的字符读完为后,才等待用户按键。spa


举例以下:.net

char ch;
ch = getchar();   // 接收用户输入的第一个字符,并赋值给字符变量ch  返回值为输入第一个字符的ASCII码




=========然并卵的分割线,如下转自 http://www.jb51.net/article/36848.htm《基于C语言EOF与getchar()的使用详解》=====================unix

但愿本文能够对初学C的朋友提供一点帮助,也但愿能和其余朋友进行交流。其中理解不对的地方若能获得指正和建议,本人将不胜感激
 
 

大师级经典的著做,要字斟句酌的去读,去理解。之前在看K&R的The C Programming Language(SecondEdition)
第1.5节的字符输入/输出,被getchar()和EOF所迷惑了。可能主要仍是因为没有搞清楚getchar()的工做原理和EOF的用法。所以,感受颇有必要总结一下,否则,不少琐碎的知识点长时间事后就会淡忘的,只有写下来才是最好的方法。code

其实,getchar()最典型的程序也就几行代码而已。本人所用的环境是DebianGNU/Linux,在其余系统下也同样。htm

1、getchar的两点总结:
1.getchar是以行为单位进行存取的。
当用getchar进行输入时,若是输入的第一个字符为有效字符(即输入是文件结束符EOF,Windows下为组合键Ctrl+Z, Unix/Linux下为组合键Ctrl+D),那么只有当最后一个输入字符为换行符'\n'(也能够是文件结束符EOF,EOF将在后面讨论)时, getchar才会中止执行,整个程序将会往下执行。譬以下面程序段:blog

while((c = getchar()) != EOF){
    putchar(c);
}get

执行程序,输入:abc,而后回车。则程序就会去执行puchar(c),而后输出abc,这个地方不要忘了,系统输出的还有一个回车。而后能够继续输入,再次遇到换行符的时候,程序又会把那一行的输入的字符输出在终端上。


对于getchar,确定不少初学的朋友会问,getchar不是以字符为单位读取的吗?那么,既然我输入了第一个字符a,确定知足while循环(c = getchar()) != EOF的条件阿,那么应该执行putchar(c)在终端输出一个字符a。不错,我在用getchar的时候也是一直这么想的,可是程序就恰恰不着样执 行,而是必需读到一个换行符或者文件结束符EOF才进行一次输出。

对这个问题的一个解释是,在大师编写C的时候,当时并无所谓终端输入的概念,全部的输入实际上都是按照文件进行读取的,文件中通常都是以行为单位的。因 此,只有遇到换行符,那么程序会认为输入结束,而后采起执行程序的其余部分。同时,输入是按照文件的方式存取的,那么要结束一个文件的输入就需用到EOF (Enf Of File). 这也就是为何getchar结束输入退出时要用EOF的缘由。

2.getchar()的返回值通常状况下是字符,但也多是负值,即返回EOF。

这里要强调的一点就是,getchar函数一般返回终端所输入的字符,这些字符系统中对应的ASCII值都是非负的。所以,不少时候,咱们会写这样的两行代码:
char c;
c = getchar();

这样就颇有可能出现问题。由于getchar函数除了返回终端输入的字符外,在遇到Ctrl+D(Linux下)即文件结束符EOF时,getchar ()的返回EOF,这个EOF在函数库里通常定义为-1。所以,在这种状况下,getchar函数返回一个负值,把一个负值赋给一个char型的变量是不 正确的。为了可以让所定义的变量可以包含getchar函数返回的全部可能的值,正确的定义方法以下(K&R C中特别提到了这个问题):
int c;
c = getchar();

2、EOF的两点总结(主要指普通终端中的EOF)
1.EOF做为文件结束符时的状况:

EOF虽然是文件结束符,但并非在任何状况下输入Ctrl+D(Windows下Ctrl+Z)都可以实现文件结束的功能,只有在下列的条件下,才做为文件结束符。
(1)遇到getcahr函数执行时,要输入第一个字符时就直接输入Ctrl+D,就能够跳出getchar(),去执行程序的其余部分;
(2)在前面输入的字符为换行符时,接着输入Ctrl+D;
(3)在前面有字符输入且不为换行符时,要连着输入两次Ctrl+D,这时第二次输入的Ctrl+D起到文件结束符的功能,至于第一次的Ctrl+D的做用将在下面介绍。
其实,这三种状况均可以总结为只有在getchar()提示新的一次输入时,直接输入Ctrl+D才至关于文件结束符。

2.EOF做为行结束符时的状况,这时候输入Ctrl+D并不能结束getchar(),而只能引起getchar()提示下一轮的输入。

这种状况主要是在进行getchar()新的一行输入时,当输入了若干字符(不能包含换行符)以后,直接输入Ctrl+D,此时的Ctrl+D并非文件 结束符,而只是至关于换行符的功能,即结束当前的输入。以上面的代码段为例,若是执行时输入abc,而后Ctrl+D,程序输出结果为:
abcabc

注意:第一组abc为从终端输入的,而后输入Ctrl+D,就输出第二组abc,同时光标停在第二组字符的c后面,而后能够进行新一次的输入。这时若是再次输入Ctrl+D,则起到了文件结束符的做用,结束getchar()。
若是输入abc以后,而后回车,输入换行符的话,则终端显示为:
abc //第一行,带回车
abc //第二行
//第三行

其中第一行为终端输入,第二行为终端输出,光标停在了第三行处,等待新一次的终端输入。
从这里也能够看出Ctrl+D和换行符分别做为行结束符时,输出的不一样结果。
EOF的做用也能够总结为:当终端有字符输入时,Ctrl+D产生的EOF至关于结束本行的输入,将引发getchar()新一轮的输入;当终端没有字符 输入或者能够说当getchar()读取新的一次输入时,输入Ctrl+D,此时产生的EOF至关于文件结束符,程序将结束getchar()的执行。

【补充】本文第二部分中关于EOF的总结部分,适用于终端驱动处于一次一行的模式下。也就是虽然getchar()和putchar()确实是按照每次一个字符 进行的。可是终端驱动处于一次一行的模式,它的输入只有到“\n”或者EOF时才结束,所以,终端上获得的输出也都是按行的。
若是要实现终端在读一个字符就结束输入的话,下面的程序是一种实现的方法(参考《C专家编程》,略有改动)

复制代码代码以下:

/*Edit by Godbach
    CU Blog: http://blog.chinaunix.net/u/33048/
 */
 #include <stdio.h>
 #include <stdlib.h>

 

 int 
 main(void)
 {
    int c;
    /* 终端驱动处于普通的一次一行模式 */
    system("stty raw");

    /* 如今的终端驱动处于一次一个字符模式 */
    c = getchar();
    putchar();

    /* 终端驱动处又回到一次一行模式 */
    system("stty cooked");

    return 0; }

编译运行该程序,则当如入一个字符时,直接出处一个字符,而后程序结束。 因而可知,因为终端驱动的模式不一样,形成了getchar()输入结束的条件不同。普通模式下须要回车或者EOF,而在一次一个字符的模式下,则输入一个字符以后就结束了。
相关文章
相关标签/搜索