C语言输入输出

时间:2021-05-23 02:11:07

格式化输入输出函数

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

printf()函数  

 printf()函数是格式化输出函数, 一般用于向标准输出设备按规定格式输出信息。在编写程序时经常会用到此函数。printf()函数的调用格式为:printf(“<格式化字符串>”, <参量表>);其中格式化字符串包括两部分内容: 一部分是正常字符, 这些字符将按原样输出,例如printf(“风雨兼程\n”); 另一部分是格式化规定字符, 以”%”开始, 后跟一个或几个规定字符,用来确定输出内容格式。参量表是需要输出的一系列参数, 其个数必须与格式化字符串所说明的输出参数个数一样多, 各参数之间用“,”分开, 且顺序一一对应, 否则将会出现意想不到的错误。

1. 格式化规定符
Turbo C2.0提供的格式化规定符如下:
━━━━━━━━━━━━━━━━━━━━━━━━━━
符号                                     作用
——————————————————————————
%d                                     十进制有符号整数
%u                                     十进制无符号整数
%f                                      浮点数
%s                                      字符串
%c                                      单个字符
%p                                      指针的值
%e                                      指数形式的浮点数
%x, %X                               无符号以十六进制表示的整数
%0                                      无符号以八进制表示的整数
%g                                       自动选择合适的表示法
━━━━━━━━━━━━━━━━━━━━━━━━━━
说明:
(1). 可以在“%”和字母之间插进数字表示最大场宽。例如: %9.2f 表示输出场宽为9的浮点数, 其中小数位为2, 整数位为6,小数点占一位, 不够9位右对齐。%8s 表示输出8个字符的字符串, 不够8个字符右对齐。

(2). 可以控制输出左对齐或右对齐, 即在“%”和字母之间加入一个”-” 号可说明输出为左对齐, 否则为右对齐。例如: %-7d 表示输出7位整数左对齐。如果字符串的长度或整型数位数超过说明的场宽, 将按其实际长度输出。但对浮点数, 若整数部分位数超过了说明的整数位宽度, 将按实际整数位输出;若小数部分位数超过了说明的小数位宽度, 则按说明的宽度以四舍五入输出。另外, 若想在输出值前加一些0, 就应在场宽项前加个0。例如: d 表示在输出一个小于4位的数值时, 将在前面补0使其总宽度为4位。如果用浮点数表示字符或整型量的输出格式, 小数点后的数字代表最大宽度,小数点前的数字代表最小宽度。例如: %6.9s 表示显示一个长度不小于6且不大于9的字符串。若大于9, 则第9个字符以后的内容将被删除。
(3). 可以在“%”和字母之间加小写字母l, 表示输出的是长型数。例如: %ld 表示输出long整数%lf 表示输出double浮点数。
2. 一些特殊规定字符
━━━━━━━━━━━━━━━━━━━━━━━━━━
字符                      作用
——————————————————————————
\n                        换行
\f                         清屏并换页
\r                         回车
\t                         Tab符
\xhh                     表示一个ASCII码用16进表示,
                           其中hh是1到2个16进制数
━━━━━━━━━━━━━━━━━━━━━━━━━━


scanf()函数
 scanf()函数是格式化输入函数, 它从标准输入设备(键盘) 读取输入的信息。其调用格式为:scanf(“<格式化字符串>”, <地址表>);格式化字符串包括以下三类不同的字符;
1. 格式化说明符: 格式化说明符与printf()函数中的格式说明符基本相同。
2. 空白字符: 空白字符会使scanf()函数在读操作中略去输入中的一个或多个空白字符。
3. 非空白字符: 一个非空白字符会使scanf()函数在读入时剔除掉与这个非空白字符相同的字符。地址表是需要读入的所有变量的地址, 而不是变量本身。这与printf()函数完全不同, 要特别注意。各个变量的地址之间同“,”分开。

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

(2). 可以在格式化字符串中的“%”各格式化规定符之间加入一个整数, 表示任何读操作中的最大位数。如例2中若规定只能输入10字符给字符串指针p, 则第一条scanf() 函数语句变为scanf(“s”, p);程序运行时一旦输入字符个数大于10, p就不再继续读入, 而后面的一个读入函数即scanf(“%s”, str)就会从第11个字符开始读入。实际使用scanf()函数时存在一个问题, 下面举例进行说明:当使用多个scanf()函数连续给多个字符变量输入时, 


非格式化输入输出函数
非格式化输入输出函数可以由上面讲述的标准格式化输入输出函数代替, 但这些函数编译后代码少, 相对占用内存也小, 从而提高了速度, 同时使用也比较方便。下面分别进行介绍。
puts()和gets()函数
 puts()函数用来向标准输出设备(屏幕)写字符串并换行, 其调用格式为:puts(s);其中s为字符串变量(字符串数组名或字符串指针)。puts()函数的作用与语printf(”%s\n”, s)相同。
例3:
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() 函数将接收输入的整个字符串直到回车为止。
例4
main()
{
  char s[20], *f;
  printf(“What’s your name?\n”);
  gets(s);
  puts(s);
  puts(“How old are you?”);
  gets(f);
  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() 函数将接收输入的整个字符串直到回车为止

例5

main()

{

         char s[20], *f;

         printf("What's your name?\n");

         gets(s);                      /*等待输入字符串直到回车结束*/

         puts(s);                      /*将输入的字符串输出*/

         puts("How old are you?");

         gets(f);

         puts(f);

 }

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

putchar()、getch()、getche()和getchar()函数

putchar()函数

 putchar()函数是向标准输出设备输出一个字符, 其调用格式为:putchar(ch);其中ch为一个字符变量或常量。putchar()函数的作用等同于printf("%c", ch);

 例6:

#include<stdio.h>

main()

    {

         char c:             /*定义字符变量*/

         c='B';              /*给字符变量赋值*/

         putchar(c);         /*输出该字符*/

         putchar('\x42');    /*输出字母B*/

         putchar(0x42);      /*直接用ASCII码值输出字母B*/

 }

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


getch()和getche()函数  

  这两个函数都是从键盘上读入一个字符。其调用格式为:getch(); getche();两者的区别是:getch()函数不将读入的字符回显在显示屏幕上, 而getche()函数却将读入的字符回显到显示屏幕上。

 例7:

#include<stdio.h>

main()

{

         char c, ch;

         c=getch();     /*从键盘上读入一个字符不回显送给字符变量c*/

         putchar(c);    /*输出该字符*/

         ch=getche();   /*从键盘上带回显的读入一个字符送给字符变量ch*/

         putchar(ch);

}

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

例8:

#include<stdio.h>

main()

{

         char c, s[20];

         printf("Name:");

         gets(s);

         printf("Press any key to confinue...");

         getch(); /*等待输入任一键*/

}

getchar()函数

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

例9:

#include<stdio.h>

main()

{

         char c;

         c=getchar();   /*从键盘读入字符直到回车结束*/

         putchar(c);    /*显示输入的第一个字符*/

         getch();       /*等待按任一健*/

 }


有关文件操作的函数

文件的顺序写函数

fprintf()、fputs()和fputc()函数函数fprintf()、fputs()和fputc()均为文件的顺序写操作函数,其调用格式如下:int fprintf(FILE *stream, char *format, <variable-list>);int fputs(char *string, FILE *steam);int fputc(int ch, FILE *steam);

上述三个函数的返回值均为整型量。fprintf() 函数的返回值为实际写入文件中的字罕个数(字节数)。如果写错误, 则返回一个负数, fputs()函数返回0时表明将string指针所指的字符串写入文件中的操作成功, 返回非0时, 表明写操作失败。fputc()函数返回一个向文件所写字符的值, 此时写操作成功, 否则返回EOF(文件结束结束其值为-1, 在stdio.h中定义)表示写操作错误。fprintf( ) 函数中格式化的规定与printf( ) 函数相同,   所不同的只是fprintf()函数是向文件中写入。而printf()是向屏幕输出。

下面介绍一个例子, 运行后产后一个test.dat的文件。

例11:

#include<stdio.h>

 main()

{

         char *s="That's goodnews"); /*定义字符串指针并初始化*/

         int i=617;                    /*定义整型变量并初始化*/

         FILE *fp;                     /*定义文件指针*/

         fp=fopne("test.dat", "w");    /*建立一个文字文件只写*/

         fputs("Your score of TOEFLis", fp);/*向所建文件写入一串字符*/

         fputc(':', fp);               /*向所建文件写冒号:*/

         fprintf(fp, "%d\n", i);      /*向所建文件写一整型数*/

         fprintf(fp, "%s", s);        /*向所建文件写一字符串*/

         fclose(fp);                   /*关闭文件*/

}

用DOS的TYPE命令显示TEST.DAT的内容如下所示:屏幕显示

     Your score of TOEFL is: 617

     That's good news、

fprintf()
#include <stdio.h> 
int fprintf( FILE *stream, const char *format, ... );
fprintf()函数根据指定的format(格式)发送信息(参数)到由stream(流)指定的文件.因此fprintf()可以使得信息输出到指定的文件.比如
    char name[20] = "Mary";
    FILE *out;
    out = fopen( "output.txt", "w" );
    if( out != NULL )
    fprintf( out, "Hello %s/n", name );
对于其输出格式参数,和printf()一样.
fprintf()和printf()一样工作. fprintf()的返回值是输出的字符数,发生错误时返回一个负值.
在有些地方,有这样的定义:printf(...)=fprintf(stdout,...).

fprintf是用于文件操作的,原型是int fprintf( FILE *stream, const char *format [, argument ]...);

举例用法:

[cpp] view plai copy
  1. #include <stdio.h>  
  2. #include <process.h>  
  3.   
  4. FILE *stream;  
  5.   
  6. void main( void )  
  7. {  
  8. int i = 10;  
  9. double fp = 1.5;  
  10. char s[] = "this is a string";  
  11. char c = '/n';  
  12.   
  13. stream = fopen( "fprintf.out""w" );  
  14. fprintf( stream, "%s%c", s, c );  
  15.   
  16. fprintf( stream, "%d/n", i );  
  17. fprintf( stream, "%f/n", fp );  
  18. fclose( stream );  
  19. system( "type fprintf.out" );  
  20. }   

屏幕输出:

this is a string
10
1.500000

printf就是在屏幕打印出一段字符串来啊
原型是int printf( const char *format [, argument]... );
是标准输出。

3:printf、sprintf与fprintf 的用法区分

1.printf 是和标准输出文件(stdout)关联的,fprintf 则没有这个限制.
 
2.fprintf是用于文件操作的,原型是int fprintf( FILE *stream, const char *format [, argument ]...);

3.sprintf是格式化输出到一个字符串,fprintf是格式化输出到一个stream,通常是到文件。
 
int  fprintf(FILE *stream,const char *format[ ,argument]...);  
int  sprintf(char *buffer,const char *format[,argument] ...);

 

分析以下的程序:

[cpp] view plain copy
  1. #include<stdio.h>  
  2. #include<stdlib.h>  
  3. #include<iostream.h>  
  4. int main()   
  5. {   
  6.     //声明变量  
  7.     char ch;  
  8.     char str[20];  
  9.     int n;  
  10.     float x;  
  11.   
  12.     //用stdin从键盘上输入数据  
  13.     fprintf(stdout,"ch str/n");  
  14.     fscanf(stdin,"%c %s",&ch,str);  
  15.     fprintf(stdout,"n    x /n");  
  16.     fscanf(stdin,"%d  %f",&n,&x);  
  17.     cout<<"----------------"<<endl;  
  18.   
  19.     //输出显示  
  20.     fprintf(stdout,"ch=%c str=%s",ch,str);  
  21.     fprintf(stdout,"/nn=%d x=%f",n,x);  
  22.     cout<<endl;  
  23. }  

 

这个程序是让你认识到区分数据类型输入的。
fscanf(stdin,"%c %s",&ch,str);是让你输入一个字符和一个字符串。
如果你只输入一个字符串那么程序就会自动截取第一个字母为字符,而输出。

fscanf(stdin,"%d %f",&n,&x);是让你输入一个整形和一个浮点数。
最后输出。