当前位置:文档之家› C语言输入输出函数全解

C语言输入输出函数全解

C语言输入输出函数全解
C语言输入输出函数全解

文章1

Turbo C2.0标准输入输出函数和文件的输入输出函数。

通过本节的学习可以使读者掌握Turbo C2.0的屏幕输出、键盘输入输出以及磁盘文件的

读写函数

1.1 标准输入输出函数

1.1.1 格式化输入输出函数

Turbo C2.0 标准库提供了两个控制台格式化输入、输出函数printf( ) 和

scanf(), 这两个函数可以在标准输入输出设备上以各种不同的格式读写数据。

printf()函数用来向标准输出设备(屏幕)写数据; scanf() 函数用来从标准输入

设备(键盘)上读数据。下面详细介绍这两个函数的用法。

一、printf()函数

printf()函数是格式化输出函数, 一般用于向标准输出设备按规定格式输出

信息。在编写程序时经常会用到此函数。printf()函数的调用格式为:

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

其中格式化字符串包括两部分内容: 一部分是正常字符, 这些字符将按原

样输出; 另一部分是格式化规定字符, 以"%"开始, 后跟一个或几个规定字符,

用来确定输出内容格式。

参量表是需要输出的一系列参数, 其个数必须与格式化字符串所说明的输出

参数个数一样多, 各参数之间用","分开, 且顺序一一对应, 否则将会出现意想

不到的错误。

1. 格式化规定符

Turbo C2.0提供的格式化规定符如下:

━━━━━━━━━━━━━━━━━━━━━━━━━━

符号作用

──────────────────────────

%d 十进制有符号整数

%u 十进制无符号整数

%f 浮点数

%s 字符串

%c 单个字符

%p 指针的值

%e 指数形式的浮点数

%x, %X 无符号以十六进制表示的整数

%0 无符号以八进制表示的整数

%g 自动选择合适的表示法

━━━━━━━━━━━━━━━━━━━━━━━━━━

说明:

(1). 可以在"%"和字母之间插进数字表示最大场宽。

例如: %3d 表示输出3位整型数, 不够3位右对齐。

%9.2f 表示输出场宽为9的浮点数, 其中小数位为2, 整数位为6,

小数点占一位, 不够9位右对齐。

%8s 表示输出8个字符的字符串, 不够8个字符右对齐。

如果字符串的长度、或整型数位数超过说明的场宽, 将按其实际长度输出。

但对浮点数, 若整数部分位数超过了说明的整数位宽度, 将按实际整数位输出; 若小数部分位数超过了说明的小数位宽度, 则按说明的宽度以四舍五入输出。

另外, 若想在输出值前加一些0, 就应在场宽项前加个0。

例如: %04d 表示在输出一个小于4位的数值时, 将在前面补0使其总宽度为4位。

如果用浮点数表示字符或整型量的输出格式, 小数点后的数字代表最大宽度, 小数点前的数字代表最小宽度。

例如: %6.9s 表示显示一个长度不小于6且不大于9的字符串。若大于9, 则第9个字符以后的内容将被删除。

(2). 可以在"%"和字母之间加小写字母l, 表示输出的是长型数。

例如: %ld 表示输出long整数

%lf 表示输出double浮点数

(3). 可以控制输出左对齐或右对齐, 即在"%"和字母之间加入一个"-" 号可说明输出为左对齐, 否则为右对齐。

例如: %-7d 表示输出7位整数左对齐

%-10s 表示输出10个字符左对齐

2. 一些特殊规定字符

━━━━━━━━━━━━━━━━━━━━━━━━━━

字符作用

──────────────────────────

\n 换行

\f 清屏并换页

\r 回车

\t Tab符

\xhh 表示一个ASCII码用16进表示,

其中hh是1到2个16进制数

━━━━━━━━━━━━━━━━━━━━━━━━━━

由本节所学的printf()函数, 并结合上一节学习的数据类型, 编制下面的程序, 以加深对Turbo C2.0数据类型的了解

例1

#include

#include

int main()

{

char c, s[20], *p;

int a=1234, *i;

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();

retunr 0;

}

上面结果中的地址值在不同计算机上可能不同。

例1.中第一条语句#include的含义是调用另一个文件stdio.h, 这是一个头文件,

其中包括全部标准输入输出库函数的数据类型定义和函数说明。

Turbo C2.0对每个库函数便用的变量及函数类型都已作了定义与说明, 放在相应头文件"*.h"中, 用户用到这些函数时必须要用#include<*.h>或#include"*. h"语句调用相应的头文件, 以供连接。若没有用此语句说明, 则连接时将会出现错误

二、scanf()函数

scanf()函数是格式化输入函数, 它从标准输入设备(键盘) 读取输入的信息。其调用格式为: scanf("<格式化字符串>", <地址表>);

格式化字符串包括以下三类不同的字符;

1. 格式化说明符: 格式化说明符与printf()函数中的格式说明符基本相同。

2. 空白字符: 空白字符会使scanf()函数在读操作中略去输入中的一个或多个空白字符。

3. 非空白字符: 一个非空白字符会使scanf()函数在读入时剔除掉与这个非空白字符相同的字符。

地址表是需要读入的所有变量的地址, 而不是变量本身。这与printf()函数

完全不同, 要特别注意。各个变量的地址之间同","分开。

例2:

main()

{

int i, j;

printf("i, j=?\n");

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

}

上例中的scanf()函数先读一个整型数, 然后把接着输入的逗号剔除掉,最后读入另一个整

型数。如果","这一特定字符没有找到, scanf()函数就终止。若参数之间的分隔符为空格, 则参数

之间必须输入一个或多个空格。

说明:

(1). 对于字符串数组或字符串指针变量, 由于数组名和指针变量名本身就是地址, 因此

使用scanf()函数时, 不需要在它们前面加上"&"操作符。

例3

mian()

{

char *p, str[20];

scanf("%s", p); /*从健盘输入字符串*/

scanf("%s", str);

printf("%s\n", p); /*向屏幕输出字符串*/

printf("%s\n", str);

}

(2). 可以在格式化字符串中的"%"各格式化规定符之间加入一个整数, 表示任何读操作中的最

大位数。

如例3中若规定只能输入10字符给字符串指针p, 则第一条scanf() 函数语句变为

scanf("%10s", p);

程序运行时一旦输入字符个数大于10, p就不再继续读入, 而后面的一个读入函数即scanf("%s", str)就会从第11个字符开始读入。

实际使用scanf()函数时存在一个问题.

下面举例进行说明:

当使用多个scanf()函数连续给多个字符变量输入时, 例如:

main()

{

char c1, c2;

scanf("%c", &c1);

scanf("%c", &c2);

printf("c1 is %c, c2 is %c", c2\1, c2);

}

运行该程序, 输入一个字符A后回车 (要完成输入必须回车), 在执行scanf("%c", &c1)时, 给变量c1赋值"A", 但回车符仍然留在缓冲区内, 执行输入语句scanf("%c", &c2)时, 变量c2输

出的是一空行, 如果输入AB后回车, 那么输出结果为: c1 is A, c2 is B。

要解决以上问题, 可以在输入函数前加入清除函数fflush()( 这个函数的使用方法将在本节最后讲述)。修改以上程序变成:

#include

main()

{

char c1, c2;

scanf("%c", &c1);

fflush(stdin);

scanf("%c", &c2);

printf("c1 is %c, c2 is %c", c1, c2); }

1.1.2 非格式化输入输出函数

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

一、puts()和gets()函数

1. puts()函数

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

puts(s);

其中s为字符串变量(字符串数组名或字符串指针)。

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

例4:

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() 函数将接收输入的整个字符串直到回车为止。

例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()函数

1. putchar()函数

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

putchar(ch);

其中ch为一个字符变量或常量。

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

例6:

#include

main()

{

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

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

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

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

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

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

2. getch()、getche()和getchar()函数

(1) getch()和getche()函数

这两个函数都是从键盘上读入一个字符。其调用格式为:

getch();

getche();

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

例7:

#include

main()

{

char c, ch;

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

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

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

putchar(ch);

}

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

等功能。

例8:

#include

main()

{

char c, s[20];

printf("Name:");

gets(s);

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

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

}

(2) getchar()函数

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

getchar()函数的调用格式为:

getchar();

例9:

#include

main()

{

char c;

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

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

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

}

文章2

c语言输入输出函数

C语言输入输出函数有很多,标准I/O函数中包含了如下几个常用的函数:

Scanf() ,

printf() ,

getc() ,

putc() ,

getchar() ,

putchar() ,

gets() ,

puts() ,

fgets() ,

fputs() ,

fgetc() ,

fputc() ,

fscanf() ,

fprintf() 等……….

int scanf(const char *format, arg_list)

scanf主要从标准输入流中获取参数值,format为指定的参数格式及参数类型,如scanf("%s,%d",str,icount);

它要求在标准输入流中输入类似"hello word,1000"这样的字符串,同时程序会将" hello word "给str,1000给icount.

scanf函数的返回值为int值,即成功赋值的个数,在上例中如果函数调用成功,则会返回2,所以我们在写程序时,可以通过

语句if(scanf("%s,%d",str,icount) != 2){...}来判断用户输入是否正确.

int printf(const char *format, arg_list)

printf主要是将格式化字符串输出到标准输出流中,在stdio.h头文件中定义了标准的输入和输出,分别是stdin,stdout.

arg_list可以是变量名,也可以是表达式,但最终都会以值的形式填充进format中.

int getc(FILE *fp)

getc主要是从文件中读出一个字符.常用的判断文件是否读取结束的语句为:(ch = getc(fp)) != EOF.EOF 为文件结束标志,

定义在stdio.h中,就像EXIT_SUCCESS,EXIT_FAILURE定义在stdlib.h中一样,文件也可以被理解为一种流,

所以当fp为stdin

时,getc(stdin)就等同于getchar()了.

int putc(int ch,FILE *fp)

putc主要是把字符ch写到文件fp中去.如果fp为stdout,则putc就等同于putchar()了.

int getchar(void)

getchar主要是从标准输入流读取一个字符.默认的标准输入流即stdio.h中定义的stdin.但是从输入流中读取字符时又

涉及到缓冲的问题,所以并不是在屏幕中敲上一个字符程序就会运行,一般是通过在屏幕上敲上回车键,然后将回车前的字符

串放在缓冲区中,getchar就是在缓冲区中一个一个的读字符.当然也可以在while循环中指定终止字符,如下面的语句:

while ((c = getchar()) != '#')这是以#来结束的.

int putchar(int ch)

putchar(ch)主要是把字符ch写到标准流stdout中去.

char * gets(char *str)

gets主要是从标准输入流读取字符串并回显,读到换行符时退出,并会将换行符省去.

int puts(char *str)

puts主要是把字符串str写到标准流stdout中去,并会在输出到最后时添加一个换行符.

char *fgets(char *str, int num, FILE *fp)

str是存放读入的字符数组指针,num是最大允许的读入字符数,fp是文件指针.fgets的功能是读一行字符,该行的字符数

不大于num-1.因为fgets函数会在末尾加上一个空字符以构成一个字符串.另外fgets在读取到换行符后不会将其省略.

int fputs(char *str, file *fp)

fputs将str写入fp.fputs与puts的不同之处是fputs在打印时并不添加换行符.

int fgetc(FILE *fp)

fgetc从fp的当前位置读取一个字符.

int fputc(int ch, file *fp)

fputc是将ch写入fp当前指定位置.

int fscanf(FILE *fp, char *format,...)

fscanf按照指定格式从文件中出读出数据,并赋值到参数列表中.

int fprintf(FILE *fp, char *format,...)

fprintf将格式化数据写入流式文件中.

字符串输入:

gets()

char name[20];

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

gets(name);

printf("Nice name %s",name);

它使用一个地址把字符串赋予name。

char name[20];

char *p;

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

p=gets(name);

printf("%s?Oh,Nice name %s\n",name,p);

get()的代码使用return 关键字返回字符串的地址,程序把这个地址分配给指针p。

fgets()

fgets()是为文件I/O而设计的,处理键盘输入不是特别方便。

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

p=fgets(name,20,stdin);

printf("%s?Oh,Nice name %s\n",name,p);

*fgets()的第二个参数说明最大读入的字符数。如果这个参数值为n,那么fgets()就会读取最多n-1个字符或读完一个换行符为止。两个条件满足任意一个结束。

*fgets()读取到换行符,就会把它存到字符串里,而不是想gets()那样丢弃它。

*fgets()的第三个参数说明读哪个文件。从键盘上读数据时,可以使用stdin(代表standard input)作为参数。

scanf()

char name1[11], name2[11];

int count;

printf("\nPlease write down 2 names...\n");

count=scanf("%5s %6s",name1,name2);

printf("\nname1:%s\nname2:%s",name1,name2);

scanf()允许指定输入字符串长度等格式。上面的程序如果输入"liujiajia liujiajia",程序将输出"name1:liuji name2:liujia";

字符串输出:

puts()

char str[15]="hello world";

const char *str2="HELLO WORLD";

puts(str);

puts(str2);

puts(&str[5]);

puts(str2+2);

puts()显示字符串时自动在其后添加一个换行符。

puts(&str[5]);将输出从str的第六个元素开始到字符串结束。

puts(str2+2);将输出从str2的地址向后移动两个字符开始到字符串结束。

fputs()

fputs(str,stdout);

fputs(str2,stdout);

fputs(&str[5],stdout);

fputs(str2+2,stdout);

*fputs()第二个参数表示要写的文件。可以使用stdout(代表standard output)作为参数。

*fputs()不自动输出换行符,这与puts()不太相同。

文章3

C语言输入输出总结:

语言中基本的输入输出函数有:

putchar ():把变量中的一个字符常量输出到显示器屏幕上;

getchar ();从键盘上输入一个字符常量,此常量就是该函数的值;

printf ();把键盘中的各类数据,加以格式控制输出到显示器屏幕上;

scanf ();从键盘上输入各类数据,并存放到程序变量中;

puts ():把数组变量中的一个字符串常量输出到显示器屏幕上;

gets ():从键盘上输入一个字符串常量并放到程序的数组中.

sscanf(); 从一个字符串中提取各类数据。

putchar() 和 getchar() 顾名思议就是从输入流中获取一个字符和输出一个字符,比较简单,不再多讲。

例子如下:

char c = getchar();

putchar(c);

格式化输入输出scanf()和printf()是最有用的,所以重点讲一下。

printf():

一般形式:

printf("格式控制".输出列表);

eg : printf("a=%d,b=%f,c=%c\n",a,b,c);

1;格式控制.

格式控制是用双引号括起来的字符串,也称"转换控制字符串",它包含以下两部分信息.

格式说明:由"%"和格式字符组成,如%d,%f,%c,他的作用是把输出数据转换为指定格式输出,格式的说明总是由"%"字符开始的.

普通字符:需要原样输出的字符,或者是一些有特殊含义的字符,如\n,\t。

2;输出列表

就是需要输出的一些数据,也可以是表达式,如果在函数中需要输出多个变量或表达式,则要用逗号隔开.

一些特殊字符的输出:

单引号,双引号,和反斜杠的输出在前面加转义字符”\”

如:”\’” , “\”” , “\\”

%的输出用两个连在一起的%%,即printf(“%%”);

常用的格式说明如下:

格式字符

d 以十进制形式输出带符号整数(正数不输出符号)

o 以八进制形式输出无符号整数(不输出前缀O)

x 以十六进制形式输出无符号整数(不输出前缀OX)

u 以十进制形式输出无符号整数

f 以小数形式输出单精度实数

lf以小数形式输出双精度实数

e 以指数形式输出单、双精度实数

g 以%f%e中较短的输出宽度输出单、双精度实数

c 输出单个字符

s 输出字符串

这里强调一下:网上很多文章都说f 和lf是一样的,即不管单精度,双精度浮点数,都可以用f, 但我在POJ上做过测试,输出Double时用f确实也可以,但读入时,用f就报WA,所以大家如果对Double进行读写的话,都用lf吧。

说到Double,再啰嗦一句,建议大家要用到浮点数时都用Double,不要用float,因为在很多情况下,float精度不够会导致WA。

特殊:

对64位整数的输入输出,在POJ上的C++环境下(即VC),64位整数是:

_ _int64 (注意int前面是两个下划线)

输入输出格式为”%I64d”.

在G++环境下(即Dev C++) 64位整数是

long long

输入输出格式为”%lld”.

输出宽度

用十进制整数来表示输出的最少位数。注意若实际位数多于定义的宽度,则按实际位数输出,若实际位数少于定义的宽度则补以空格或0。

精度

精度格式符以“.”开头,后跟十进制整数。意义是:如果输出数字,则表示小数的位数;如果输出的是字符,则表示输出字符的个数;若实际位数大于所定义的精度数,则截去超过的部分。

标志格式字符

- 结果左对齐,右边填空格

+ 输出符号(正号或负号)空格输出值为正时冠以空格,为负时冠以负号

例如:

double c=24212345.24232;

printf(“%020.4”); 表示输出精确到小数点后4位,输出占20位,若有空余的位补0.

scanf:

scanf的很多用法都是和printf对应的,故不再赘述。

说一下scanf一个特别好用的地方,就是可以滤去一些不想要的东西。

举例说明如下:

比如输入为日期 yyyy-mm-dd,就可以这样写:

int year,moth,day;

scanf(“%d-%d-%d”,&year,&moth,&day);

再比如:

scanf("%3d %*3d %2d",&m,&n); 输入113 118 69回车(系统将113赋予m,将69赋予n,因为*号表示跳过它相应的数据所以118不赋予任何变量)

puts()用的不多,且基本都能用printf()代替,故不再多说。

gets()是从输入流中获取一行字符串放入字符数组中:

char in[100];

gets(in);

大家可能最容易出错的地方就是字符串的输入,所以强调一下:

能进行字符,字符串输入的有:

getchar(), scanf(“%c”); scanf(“%s”), gets()

其中getchar() 和 scanf(“%c”)的功能是一样的。

需要注意的是,这两个函数读入的是输入流中当前位置的字符,

比如:

scanf(“%d”,&n);

c = getchar();

假设输入 67/ (假设“/”代表回车),则第一个scanf读入一个整数67后,当前输入流的位置是67之后,即指向回车符,所以第二个getchar()读入的就是一个回车符了,即 c = ‘\n’。

同样,gets()也是从当前位置读入一行字符串。

比如:

scanf(“%d”,&n);

gets(str);

此时读入字符数组中的字符串就是“\n”了

所以通常在用scanf读入一个非字符串的类型之后,如果要读入字符,或字符数组,都用一个额外的getchar()把回车符读掉,若后面跟的不止一个回车符,可能还有多余的空格的话,就用gets()读掉。

和以上不同的是,scanf(“%s”) 读入的时候是会忽略掉空格,回车和制表符的。并且以空格,回车和制表符作为字符串结束的标志。

相关主题
文本预览
相关文档 最新文档