欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

C语言的输入和输出函数

程序员文章站 2024-02-17 21:49:34
...

C语言提供了两个控制台格式化输入、输出函数printf() 函数scanf() 函数,这两个函数可以在标准输入输出设备上以各种不同的格式读写数据。printf()函数用来向标准输出设备(屏幕)写数据; scanf() 函数用来从标准输入设备(键盘)上读数据。

一、格式化输出函数—printf()函数

printf()函数是格式化输出函数,一般用于向标准输出设备按规定格式输出信息。在编写程序时经常会用到此函数。printf()函数的调用格式为:

printf("<格式化字符串>", <参量表>);

其中格式化字符串包括两部分内容:一部分是正常字符,这些字符将按原样输出;另一部分是格式化规定字符,以 “%”开始,后跟一个或几个规定字符,用来确定输出内容格式。参量表是需要输出的一系列参数,其个数必须与格式化字符串所说明的输出参数个数一样多,各参数之间用 “,”分开, 且顺序一一对应,否则将会出现意想不到的错误。

1、格式化规定符
C语言的输入和输出函数
特别注意: %0 和 %x 表示的都是 无符号的整形

说明:
(1)、可以在“%”和字母之间插进数字表示最大场宽。例如: %9.2f 表示输出场宽为9的浮点数,其中小数位为2,整数位为6,小数点占一位,不够9位右对齐。%8s 表示输出8个字符的字符串,不够8个字符右对齐。

(2)、可以控制输出左对齐或右对齐,即在“%”和字母之间加入一个“-”号可说明输出为左对齐,否则默认为右对齐。例如:%-7d 表示输出7位整数左对齐。

(3)、对于字符串的长度或整型数位数超过说明的场宽,将按其实际长度输出。但对浮点数,若整数部分位数超过了说明的整数位宽度,将按实际整数位输出;若小数部分位数超过了说明的小数位宽度,则按说明的宽度以四舍五入输出。

(4)、若想在输出值前加一些0,就应在场宽项前加个0。例如:%04d 表示在输出一个小于4位的数值时,将在前面补0使其总宽度为4位。

(5)、如果用浮点数表示字符或整型量的输出格式,小数点后的数字代表最大宽度,小数点前的数字代表最小宽度。例如:%6.9s 表示显示一个长度不小于6且不大于9的字符串。若大于9,则第9个字符以后的内容将被删除。

(6)、可以在“%”和字母之间加小写字母l, 表示输出的是长型数。例如: %ld 表示输出long整数%lf 表示输出double浮点数。

2、一些特殊规定字符
C语言的输入和输出函数

例程:

#include <stdio.h>
#include <string.h> 

int main() 
{
    char c, s[20], *p;
    int a=1234, b, *i = &b; 
    float f=3.141592653589;
    double x=0.12345678987654321; 
    p="How do you do"; 
    strcpy(s,"Hello, Comrade");
    *i=12; 
    c='\x41';

    printf("a=%d\n", a);    /*结果输出十进制整数a=1234*/ 
    printf("a=%6d\n", a);   /*结果输出6位十进制数a= 1234*/ 
    printf("a=%06d\n", a);  /*结果输出6位十进制数a=001234*/ 
    printf("a=%2d\n", a);   /*a超过2位, 按实际值输出a=1234*/ 
    printf("*i=%4d\n", *i); /*输出4位十进制整数*i= 12*/ 
    printf("*i=%-4d\n", *i);/*输出左对齐4位十进制整数*i=12*/
    printf("i=%p\n", i);    /*输出地址i=06E4*/ 
    printf("f=%f\n", f);    /*输出浮点数f=3.141593*/ 
    printf("f=6.4f\n", f);  /*输出6位其中小数点后4位的浮点数f=3.1416*/
    printf("x=%lf\n", x);   /*输出长浮点数x=0.123457*/ 
    printf("x=%18.16lf\n", x);/*输出18位其中小数点后16位的长浮点数x=0.1234567898765432*/
    printf("c=%c\n", c);    /*输出字符c=A*/
    printf("c=%x\n", c);    /*输出字符的ASCII码值c=41*/ 
    printf("s[]=%s\n", s);  /*输出数组字符串s[]=Hello, Comrade*/ 
    printf("s[]=%6.9s\n", s);/*输出最多9个字符的字符串s[]=Hello, Co*/ 
    printf("s=%p\n", s);    /*输出数组字符串首字符地址s=FFBE*/
    printf("*p=%s\n", p);   /* 输出指针字符串p=How do you do*/ 
    printf("p=%p\n", p);    /*输出指针的值p=0194*/ 

    getch(); 
    return 0; 
}

二、格式化输入函数—scanf()函数

scanf()函数是格式化输入函数,它从标准输入设备(键盘) 读取输入的信息。其调用格式为:

scanf("<格式化字符串>", <地址表>);

格式化字符串包括以下三类不同的字符;
1、格式化说明符:格式化说明符与printf()函数中的格式说明符基本相同。
2、空白字符:空白字符会使scanf()函数在读操作中略去输入中的一个或多个空白字符。
3、非空白字符:一个非空白字符会使scanf()函数在读入时剔除掉与这个非空白字符相同的字符。

地址表是需要读入的所有变量的地址,而不是变量本身。这与printf()函数完全不同,要特别注意。各个变量的地址之间同“,”分开。

例 1:

int i,j;
scanf("%d, %d", &i, &j);

上例中的scanf()函数先读一个整型数,然后把接着输入的逗号剔除掉,最后读入另一个整型数。如果“,”这一特定字符没有找到,scanf()函数就终止。若参数之间的分隔符为空格,则参数之间必须输入一个或多个空格。

几点说明:
(1)、对于字符串数组或字符串指针变量,由于数组名和指针变量名本身就是地址,因此使用scanf()函数时,不需要在它们前面加上“&”操作符。

例2:

int main()
{
    char *p, str[20];
    scanf("%s", p);//本就是地址,无需加&
    scanf("%s", str);
    printf("%s\n", p);
    printf("%s\n", str);
}

(2)、可以在格式化字符串中的“%”各格式化规定符之间加入一个整数,表示任何读操作中的最大位数。
如例2中若规定只能输入10字符给字符串指针p, 则第一条scanf() 函数语句变为:

scanf(“%10s”, p);

程序运行时一旦输入字符个数大于10,p就不再继续读入,而后面的一个读入函数即scanf(“%s”, str)就会从第11个字符开始读入。实际使用scanf()函数时存在一个问题,下面举例进行说明:
当使用多个scanf()函数连续给多个字符变量输入时,例如:

例3:

int main()
{
  char c1, c2;
  scanf("%c", &c1);//注意是连续输入字符变量char
  scanf("%c", &c2);
  printf("c1 is %c, c2 is %c", c2, c2);
}

运行该程序,输入一个字符A后回车 (要完成输入必须回车), 在执行scanf(“%c”, &c1)时, 给变量c1赋值”A”, 但回车符仍然留在缓冲区内,执行输入语句scanf(”%c”, &c2)时, 变量c2输出的是一空行,如果输入AB后回车, 那么输出结果为: c1 is A, c2 is B。要解决以上问题,可以在输入函数前加入清除函数fflush(stdin)。修改以上程序变成:

#include<stdio.h>
int main()
{
  char c1, c2;
  scanf(“%c”, &c1);
  fflush(stdin);
  scanf(“%c”, &c2);
  printf(“c1 is %c, c2 is %c”, c1, c2);
}

三、非格式化输入输出函数

非格式化输入输出函数可以由上面讲述的标准格式化输入输出函数代替,但这些函数编译后代码少,相对占用内存也小,从而提高了速度,同时使用也比较方便。下面分别进行介绍。

1、 puts()函数
puts()函数用来向标准输出设备(屏幕)写字符串并换行,其调用格式为:

puts(s);//s为字符串变量(字符串数组名或字符串指针)

puts()函数的作用与语printf(“%s\n”, s)相同。

例:

int main()
{
  char s[20], *f;
  strcpy(s, "Hello! Turbo C2.0");
  f="Thank you";
  puts(s);
  puts(f);
}

说明:
(1)、puts()函数只能输出字符串,不能输出数值或进行格式变换。
(2)、可以将字符串直接写入puts()函数中。如:puts(“Hello, Turbo C2.0”);

2、gets()函数
gets()函数用来从标准输入设备(键盘)读取字符串直到回车结束,但回车符不属于这个字符串。其调用格式为:

gets(s);//s为字符串变量(字符串数组名或字符串指针)

gets(s)函数与scanf(“%s”, &s)相似,但不完全相同,使用scanf(“%s”,&s)函数输入字符串时存在一个问题,就是如果输入了空格会认为输入字符串结束,空格后的字符将作为下一个输入项处理,但gets() 函数将接收输入的整个字符串直到回车为止,gets()会吸收空格

例:

int main()
{
    char s[20], *f;
    printf("What's your name?\n");
    gets(s);  /*等待输入字符串直到回车结束*/
    puts(s);  /*将输入的字符串输出*/
    puts("How old are you?");
    gets(f);
    puts(f);
 }

说明:
gets(s)函数中的变量s为一字符串。如果为单个字符, 编译连接不会有错误, 但运行后会出现”Null pointer asignmemt”的错误。

3、putchar()函数
putchar()函数是向标准输出设备输出一个字符,其调用格式为:

putchar(ch);//其中ch为一个字符变量或常量

putchar()函数的作用等同于printf(“%c”, ch);

例:

int main()
{
    char c;          /*定义字符变量*/
    c='B';           /*给字符变量赋值*/
    putchar(c);      /*输出该字符*/
    putchar('\x42'); /*输出字母B*/
    putchar(0x42);   /*直接用ASCII码值输出字母B*/
 }

从本例中的连续四个字符输出函数语句可以分清字符变量的不同赋值方法。

4、getchar()函数
getchar()函数也是从键盘上读入一个字符,并回显。它与前面函数的区别在于:getchar()函数等待输入直到按回车才结束,回车前的所有输入字符都会逐个显示在屏幕上,但只有第一个字符作为函数的返回值。getchar()函数的调用格式为:

getchar();

例:

int main()
{
    char c;
    c=getchar();   /*从键盘读入字符直到回车结束*/
    putchar(c);    /*显示输入的第一个字符*/
    getch();       /*等待按任一健*/
}

5、getch()和getche()函数
这两个函数都是从键盘上读入一个字符。其调用格式为:

getch(); 
getche();

两者的区别是getch()函数不将读入的字符回显在显示屏幕上,而getche()函数却将读入的字符回显到显示屏幕上。

例:

int main()
{
    char c, ch;
    c=getch();     /*从键盘上读入一个字符不回显送给字符变量c*/
    putchar(c);    /*输出该字符*/
    ch=getche();   /*从键盘上带回显的读入一个字符送给字符变量ch*/
    putchar(ch);
}

利用回显和不回显的特点,这两个函数经常用于交互输入的过程中完成暂停等功能。如下例子所示:

例:

int main()
{
    char c, s[20];
    printf("Name:");
    gets(s);
    printf("Press any key to confinue...");
    getch(); /*等待输入任一键,按键内容不会显示*/
}