", <" />
当前位置:文档之家› C语言Printf和Scan函数的使用方法

C语言Printf和Scan函数的使用方法

C语言Printf和Scan函数的使用方法一printf()函数是格式化输出函数, 一般用于向标准输出设备按规定格式输出信息。

在编写程序时经常会用到此函数。

printf()函数的调用格式为:printf("<格式化字符串>", <参量表>);其中格式化字符串包括两部分内容: 一部分是正常字符, 这些字符将按原样输出; 另一部分是格式化规定字符, 以"%"开始, 后跟一个或几个规定字符,用来确定输出内容格式。

参量表是需要输出的一系列参数, 其个数必须与格式化字符串所说明的输出参数个数一样多, 各参数之间用","分开, 且顺序一一对应, 否则将会出现意想不到的错误。

格式化字符串的格式是:%[标志][输出最小宽度][.精度][长度]格式字符1. 标志:标志字符为-、+、#、空格四种,其意义下表所示:标志意义- 结果左对齐,右边填空格+ 输出符号(正号或负号)空格输出值为正时冠以空格,为负时冠以负号# 对c,s,d,u类无影响;对o类,在输出时加前缀o;对x类,在输出时加前缀0x;对e,g,f 类当结果有小数时才给出小数点()例1:#include<stdio.h>main(){int a=100;float b=123.255;printf("a=%d ",a);printf("a=%10d ",a);printf("a=%-10d ",a);printf("a=%+d ",a);printf("a=% d ",a);printf("a=%#o ",a);printf("a=%#x ",a);printf("b=%#f ",b);}运行结果a=100a= 100a=100a=+100a= 100a=0144a=0x64b=123.254997 ()2.输出最小宽度:用十进制整数来表示输出的最少位数。

(至少要输出这么多位!)若实际位数多于定义的宽度:则按实际位数输出。

若实际位数少于定义的宽度:则右对齐,左边留空。

有负号,左对齐,右边留空表示宽度的数字以0开始,则右对齐,左边留空。

例2 #include<stdio.h>main(){int a=3456;printf("a=%3d ",a); //若实际位数多于定义的宽度:则按实际位数输出printf("a=%10d ",a); //若实际位数少于定义的宽度:则右对齐,左边留空printf("a=%-10d ",a); //若实际位数少于定义的宽度:有负号,左对齐,右边留空 printf("a=%010d ",a); //若实际位数少于定义的宽度:表示宽度的数字以0开始,则右对齐,左边留空printf("a=%-010d ",a); //左对齐,0无意义。

}运行结果:a=3456a= 3456a=3456a=0000003456a=34563.精度:精度格式符以“.”开头,后跟十进制整数。

意义是:如果输出数字,则表示小数的位数;若实际位数大于所定义的精度数,则四舍五入。

若不足则补0;如果输出的是字符,则表示输出字符的个数;若实际位数大于所定义的精度数,则截去超过的部分。

例3:#include<stdio.h>main(){printf("%.3f ",12.3456);printf("%.9f ",12.3456);printf("%.3s ","abcdefg");printf("%.9s ","abcdefg");}运行结果:12.346 //四舍五入到小数点后三位12.345600000 //不足补0abcabcdefg4.长度:长度格式符为h,l两种,h表示按短整型量输出,l表示按长整型量输出5.Turbo C2.0提供的格式字符如下:━━━━━━━━━━━━━━━━━━━━━━━━━━符号作用──────────────────────────%c 单个字符%d 十进制有符号整数%e 以“科学记数法”的形式输出十进制的浮点数如2.451e+02 %f 输出十进制浮点数,不带域宽时,保留6位小数%g 选用e或f格式中较短的一个输出十进制浮点数,不输出无效零%0 无输出无符号八进制整数%p 指针的值%s 输出字符串%u 输出无符号十进制整数%x, %X 输出无符号十六进制整数(不输出前缀Ox)━━━━━━━━━━━━━━━━━━━━━━━━━━2. 一些特殊规定字符━━━━━━━━━━━━━━━━━━━━━━━━━━字符作用──────────────────────────换行f 清屏并换页回车Tab符xhh 表示一个ASCII码用16进表示,其中hh是1到2个16进制数━━━━━━━━━━━━━━━━━━━━━━━━━━使用这些转义字符时不需要加上%,可单独使用!由本节所学的printf()函数, 并结合上一节学习的数据类型, 编制下面的程序, 以加深对Turbo C2.0数据类型的了解。

例1#include<stdio.h>#include<string.h>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 ", a); /*结果输出十进制整数a=1234*/printf("a=%6d ", a); /*结果输出6位十进制数a= 1234*/printf("a=%06d ", a); /*结果输出6位十进制数a=001234*/printf("a=%2d ", a); /*a超过2位, 按实际值输出a=1234*/printf("*i=%4d ", *i); /*输出4位十进制整数*i= 12*/printf("*i=%-4d ", *i); /*输出左对齐4位十进制整数*i=12*/printf("i=%p ", i); /*输出地址i=06E4*/printf("f=%f ", f); /*输出浮点数f=3.141593*/printf("f=6.4f ", f); /*输出6位其中小数点后4位的浮点数f=3.1416*/printf("x=%lf ", x); /*输出长浮点数x=0.123457*/printf("x=%18.16lf ", x);/*输出18位其中小数点后16位的长浮点数x=0.1234567898765432*/printf("c=%c ", c); /*输出字符c=A*/printf("c=%x ", c); /*输出字符的ASCII码值c=41*/printf("s[]=%s ", s); /*输出数组字符串s[]=Hello, Comrade*/printf("s[]=%6.9s ", s);/*输出最多9个字符的字符串s[]=Hello,Co*/printf("s=%p ", s); /*输出数组字符串首字符地址s=FFBE*/printf("*p=%s ", p); /* 输出指针字符串p=How do you do*/printf("p=%p ", p); /*输出指针的值p=0194*/getch();retunr 0;}其他需要注意的一些问题:1.如果用浮点数表示字符或整型量的输出格式, 小数点后的数字代表最大宽度,小数点前的数字代表最小宽度。

例如: %6.9s 表示显示一个长度不小于6且不大于9的字符串。

若大于9, 则第9个字符以后的内容将被删除。

2.使用printf函数时还要注意一个问题,那就是输出表列中的求值顺序。

不同的编译系统不一定相同,可以从左到右,也可从右到左。

Turbo C是按从右到左进行的。

请看下面两个例子:例1main(){int i=8;printf("%d %d %d %d %d %d ",++i,--i,i++,i--,-i++,-i--);}运行结果8778-7-8例2main(){int i=8;printf("%d ",++i);printf("%d ",--i);printf("%d ",i++);printf("%d ",i--);printf("%d ",-i++);printf("%d ",-i--);}运行结果:9889-8-9这两个程序的区别是用一个printf语句和多个printf 语句输出。

但从结果可以看出是不同的。

为什么结果会不同呢?就是因为printf函数对输出表中各量求值的顺序是自右至左进行的。

在第一例中,先对最后一项“-i--”求值,结果为-8,然后i 自减1后为7。

再对“-i++”项求值得-7,然后i自增1后为8。

再对“i--”项求值得8,然后i再自减1后为7。

再求“i++”项得7,然后i再自增1后为8。

再求“--i”项,i先自减1后输出,输出值为7。

最后才求输出表列中的第一项“++i”,此时i 自增1后输出8。

但是必须注意,求值顺序虽是自右至左,但是输出顺序还是从左至右,因此得到的结果是上述输出结果。

二Scan函数数scanf()函数是格式化输入函数, 它从标准输入设备(键盘) 读取输入的信息。

其调用格式为:scanf("<格式化字符串>", <地址表>);格式化字符串包括以下三类不同的字符;1. 格式化说明符: 格式化说明符与printf()函数中的格式说明符基本相同。

相关主题