C语言中的getchar和putchar详解
(2012-05-09 19:04:48)
标签:
it |
分类: 零碎笔记 |
原文地址:
http://www.cnblogs.com/hdchild/archive/2009/11/19/1606457.html
一、首先给出《The_C_Programming_Language》这本书中的例子:
#include
int
{
}
这里主要解释下为什么要用int型来接受getchar函数。
很多时候,我们会写这样的两行代码:
char c;
c = getchar();
这样就很有可能出现问题。因为getchar函数除了返回终端输入的字符外,在遇到Ctrl+D(Linux下)即文件结束符EOF时,getchar ()的返回EOF,这个EOF在函数库里一般定义为-1。因此,在这种情况下,getchar函数返回一个负值,把一个负值赋给一个char型的变量是不正确的。
二、下面用一个题目来看其实如何获取字符和输出字符的。
#include "stdio.h"
main()
{
}
运行后先输入“12”,回车,再输入“34”,回车。
运行环境是redhat gcc
运行结果:
please input two characters:
12
1
2
34
3
c=1
d=2
e=
f=3
下面具体解释一下:
getchar函数每次从缓冲区中得到一个字符(包括换行符),putchar函数每次输出一个字符(包括换行符)。
首先输入了两个字符12,然后回车,注意这时写入缓存中的有3个字符1,2,回车。
程序中有四个getchar(),于是c='1',d='2',e='\n'。
这时运行到f=getchar();输入缓存中的三个字符均被前三个getchar获取,这时需要用户输入,
这里输入了34
于是f='3',4和后面的回车没有被利用。
这便是整个流程。
这里我们要注意下面几条:
1)
2)
3)
4)
5)getchar可以读入所有字符。
6)windows下如果想结束,就输入Ctrl+Z,表示EOF。