C语言输入和输出(getchar() 、 putchar() 、gets() 、 puts()、scanf() 、printf())

本文主要介绍C语言中使用getchar() 、 putchar() 、gets() 、 puts()、scanf() 和 printf()函数获取用户输入和输出,以及相关示例代码。

1、输入输出函数

C语言中stdio.h头文件中内置输入输出函数,如下列出:

  • printfscanf
  • getcharputchar
  • gets puts

输入输出函数中 scanfprintf功能比较丰富,但操作稍微复杂。

2、scanf() 和 printf() 函数

int scanf(const char *format, ...) 函数从标准输入流 stdin 读取输入,并根据提供的 format 来浏览输入。

int printf(const char *format, ...) 函数把输出写入到标准输出流 stdout ,并根据提供的格式产生输出。

format 可以是一个简单的常量字符串,但是可以分别指定 %s%d%c%f 等来输出或读取字符串、整数、字符或浮点数。还有许多其他可用的格式选项,可以根据需要使用。

1)printf()常用格式输出

格式: %[-][0][m][l]格式字符

附加格式说明字符

说 明

-

输出的数字或字符以左对齐,

右边填空格

0(数字)

输出的空位用0填充。

m(一个正整数)

输出数据的字段宽度。

如果实际位数多于m,

按实际位数输出;

如果实际位数少于m,

则补以空格或0。

.n(一个正整数)

对实数,表示输出n位小数;

对字符串,

表示截取的字符个数。

l(字母)

输出长整型整数

%d :以带符号的十进制形式输出整数
%o :以无符号的八进制形式输出整数
%x :以无符号的十六进制形式输出整数
%u :以无符号的十进制形式输出整数
%c :以字符形式输出单个字符
%s :输出字符串
%f :以小数点形式输出单、双精度实数
%e :以标准指数形式输出单、双精度实数
%g :选用输出宽度较小的格式输出实数

例如,

#include <stdio.h>
int main( )
{   
    char x='a'; 
    int i=98;
    printf("%c,%d\n",x,x);
    printf("%c,%d\n",i,i);
    printf("%3s,%-6s,%-5.2s,%4.3s,%.3s,","hello", 
    "hello","hello","hello","hello");
    float f=3.14159;
    printf("%f,%07.3f,%-7.3f,%10f,%.3f,",f,f,f,f,f);
    printf("\n,%10.1e",31.5);
    int i1=-1;
    printf("\n%d,%o,%x,%u",i1,i1,i1,i1);
    float f1=3.14159;
    printf("\n%e,%f,%lf,%g",f1,f1,f1,f1);
    return 0;
}

2)scanf()格式输入

格式符

说明

d

用于输入十进制整数

o

用于输入八进制形整数

x

用于输入十六进制整数

c

用于输入一个字符

s

用于输入字符串,

并将字符串送到一个字符数组中。

输入时以非空白字符开始,

第一个空白字符结束。

字符串以串结束标志“\0”作为其最后一个字符。

f

用于输入实数。

输入时用小数点形式或指数形式均可。

(输入双精度必须用%lf,否则不能正常输入)

e

与f作用相同

附加格式

*

表示本输入项在输入后不赋给相应的变量。(不存储)

l(字母)

用于输入长整型和双精度实型数据

m(一个正整数)

用于输入长整型和双精度实型数据

scanf()格式字符串的组成:

  • 格式符 

printf函数类似,scanf函数的格式字符串以%开始,以一个格式字符结束,中间可以插入附加字符。格式符告诉了scanf函数该读取什么样的数据。

  • 空白符 

空白符可以是空格(space,用空格键输入)、制表符(tab,用Tab键输入)和新行符(newline,用回车键输入),或者它们的组合

  • 非空白符 

除去格式说明符合空白符之外,就是非空白符。非空白符在用户输入的时候,也必须一并输入。非空白符使scanf() 在缓冲区中读一个匹配的字符并将这个字符忽略。例如,”%d,%d”使scanf()先读入一个整数,接着必须要读入一个逗号,读入到逗号后,表示格式匹配,将读入的逗号丢弃,而不像读入的整数存储到某个内存空间。读入逗号后,接着读入另一个整数。如发现不能匹配格式字符串,比如没有读到逗号,scanf()返回,读入失败。

例如,

#include <stdio.h>
int main( )
{  
    int i,j;
    scanf("%3d%3d\n",&i,&j);  // 输入:1234567↙
    printf("%d,%d\n",i,j);  // 输出  123,456 
    // 2)%后面的*格式符,用来表示在解析时,将读入的数据忽略不赋给任何变量。如:
    int i1,j1;
    scanf("%d %*d %d\n",&i1,&j1); // 输入: 123 456 789 
    printf("%d,%d\n",i1,j1);    // 输出: 123,789
    // 3)输入数据时不能指定精度。如:  
    float f;
    scanf("%7.2f\n",&f); // 输入 123.456 
    printf("%f23\n",f); // 输出 0.00000023 
    // 4) 输入双精度数使用%lf
    // 输入双精度浮点数时,务必用%lf,如下错误
    double db;
    scanf("%f\n",&db);  //输入: 123.456
    printf("%f\n",db); // 输出 : 0.000000 
    return 0;
}

3、字符输入输出(getchar/putchar)

有时在显示器屏幕上打印或从控制台获取一个字符,此时使用功能强大的printfscanf函数,则显得有点于麻烦,C提供了一个库函数putchar/getchar来实现。

int getchar(void) 函数从屏幕读取下一个可用的字符,并把它返回为一个整数。这个函数在同一个时间内只会读取一个单一的字符。可以在循环内使用这个方法,以便从屏幕上读取多个字符。

int putchar(int c) 函数把字符输出到屏幕上,并返回相同的字符。这个函数在同一个时间内只会输出一个单一的字符。可以在循环内使用这个方法,以便在屏幕上输出多个字符。

例如,

#include <stdio.h>
int main( )
{
   int c;
   printf( "请输入一个字符 :");
   c = getchar( );
   printf( "\n输入的字符是: ");
   putchar( c );
   printf( "\n");
   return 0;
}

注意:执行时会等待输入一些文本,当输入多个字符并按下回车键时,程序会继续并只会读取一个字符。

4、gets() 和 puts() 函数

puts函数功能非常单一,在显示器屏幕上输出一个字符串,并换行。gets从标准输入设备读字符串函数。可以无限读取,不会判断上限,以回车结束读取,所以程序员应该确保buffer的空间足够大,以便在执行读操作时不发生溢出。此函数在stdio.h头文件中定义的。

char *gets(char *s) 函数从 stdin 读取一行到 s 所指向的缓冲区,直到一个终止符或 EOF。

int puts(const char *s) 函数把字符串 s 和一个尾随的换行符写入到 stdout。

例如,

#include <stdio.h>
int main( )
{
   char str[100];
   printf( "请输入字符串 :");
   gets( str );
   printf( "\n输入的内容: ");
   puts( str );
   return 0;
}

注意:执行时会等待输入一些文本,当输入多个字符并按下回车键时,,程序会继续并读取一整行直到该行结束。

推荐阅读
cjavapy编程之路首页