C语言中的getchar和putchar详解

一、首先给出《The_C_Programming_Language》这本书中的例子:

#include 

int main( )
{
      int c;
      c = getchar();
  while (c != EOF)
    {
          putchar();
            c= getchar(); 
  }
    return 0;
}

这里主要解释下为什么要用int型来接受getchar函数。
很多时候,我们会写这样的两行代码:
char c;
c = getchar();
这样就很有可能出现问题。因为getchar函数除了返回终端输入的字符外,在遇到Ctrl+D(Linux下)即文件结束符EOF时,getchar ()的返回EOF,这个EOF在函数库里一般定义为-1。因此,在这种情况下,getchar函数返回一个负值,把一个负值赋给一个char型的变量是不正确的。

二、下面用一个题目来看其实如何获取字符和输出字符的。

#include "stdio.h"
main()
{
      char c,d,e,f;
      printf("please input two characters:\n");
  c=getchar();
    putchar(c);
    putchar('\n');
    d=getchar();
    putchar(d);
    putchar('\n');
    e=getchar();
    putchar(e);
    putchar('\n');
    f=getchar();
    putchar(f);
    putchar('\n');
    printf("c= %c\n",c);
    printf("d= %c\n",d);
    printf("e= %c\n",e);
    printf("f= %c\n",f);
}

运行后先输入“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) 用getchar读入时,如果不按回车符,所有输入会放入缓冲区,而不会被读入,所以执行c=getchar();时,我们输入12,如果不按回车键,1仍然不会读入;
2) 最后按下的回车键,虽是用来告诉系统输入已结束,但同时也会作为一个字符放入缓冲区,所以我们输入12,按回车后,输入流其实有三个字符:1、2、回车,而这个回车就被e读取了;
3) 12是被当做两个字符1和2(注意,不是数字1、2),而不像%d时,作为一个数字12来看待;
4) putchar()输出指定字符,不会在输出后自动换行,所以putchar(c);和putchar(d);之间要加putchar(‘\n’);如果不加的话,会把c和d两个自动(1、2)输入到同一行。
5)getchar可以读入所有字符。
6)windows下如果想结束,就输入Ctrl+Z,表示EOF。

补充:上面这个用putchar会输出字符,如果字符为\n之类的也同样输出,即换行。

还有人认为putchar、getchar和scanf、printf功能重复,甚至不如后两个,实际上略有不同:

getchar跟putchar是输入输出单字符的,printf跟scanf可以输入输出多字符,并且getchar和putchar只可以用于字符型的输入和输出,而scanf和printf可以用于整型浮点型和字符型等类型的输入和输出,这也是因为对于字符,用这两个就比前面的简单多了,你以后编得多了就知道了,希望能帮助到你

原文地址
http://www.cnblogs.com/hdchild/archive/2009/11/19/1606457.html


以上皆为个人观点,如有意见,欢迎讨论。

你可能感兴趣的:(c语言)