一般C程序可以分成三部分:输入原始数据部分、计算处理部分和输出结果部分。C语言本身无输入输出语句,为了实现输入和输出功能,在C的库函数中提供了一组输入输出函数,其中scanf和printf函数是针对标准输入输出设备(键盘和显示器)进行格式输入输出的函数。所以要使用它们,应该使用编译预处理命令将stdio.h(standard input and output header)文件include到程序文件中:
#include <stdio.h>
格式化输出函数printf(print format)调用形式
printf("格式控制字符串",输出列表); 格式字符串是以%(perent)开头的字符串,在%后面跟各种格式字符。
格式字符串的一般形式为: [标志][输入最小宽度][.精度][长度]类型 (方括号项为可选项)
格式字符类型和意义
格式字符 意义
d (decimal) 以十进制形式输出带符号整数(正数不输出符号)
o (octal) 以八进制输出无符号整数(不输出前缀o)
x,X (hex) 以十六进制形式输出无符号整数(不输出前缀0x)
u (unsigned) 以十进制形式输出无符号整数
f (float) 以小数形式输出单、双精度实数
e,E (exponectiation) 以指数形式输出单、双精度实数
g,G () 以%f戓%e中较短的输出宽度输出单、双精度实数
c (character) 输出单个字符
s (string) 输出字符串
标志字符类型和意义
标志字符 意义
- (minus) 结果左对齐,左边填空格
+ (plus) 输出符号(正号或负号)
空格 输出正时冠以空格,为负时冠以负号
# (pound) 对c,s,d,u类无影响;对o类,在输出时加前缀o;对x类,在输出时加前 缀0x;对e,g,f类当结果有小数时才给出小数点
1),输出最小宽度:用十进制整数来表示输出的最少位数。若实际位数多于定义的宽度,则按实际位数输出,若实际位数少于定义的宽度则补以空格或0.
2),精度:精度格式符以"."(point)开头,后跟十进制整数。本项的意义为:如果输出数字,则表示小数的位数;如果输出的是字符,则表示输出字符的个数;若实际位数大于所定义的数度数,则截去超过的部分。
3), 长度:长度格式符为h、l两种,h表示按短整量输出,l表示按长整型量输出。
格式化输入函数scanf(scan format),按用户指定的格式从键盘把数据输入到指定的亦是中。与printf函数相同,C语言请允许我在使用scanf函数之前不必包含stdio.h文件。
scanf("格式控制符",地址列表);
格式控制字符串的作用与printf函数相同,但不能显示非格式字符串。后面地址列表中的地址是由地址的取址运算符'&'后跟变量名组成。&取址运算符是取得我们需要内存的地址。内存地址是编译系统分配的,用户不必关心。
scanf中的格式字符串的一般形式为:
%[*][输入数据宽度][长度]类型
格式 字符意义
d 输入十进制整数
o 输入八进制整数
x 输入十六进制整数
u 输入无符号十进制整数
f或e 输入实型数(用小数形式或指数形式)
c 输入单个字符
s 输入字符串
*(star) 符:表示该输入项,读入后不赋予相应的变量,跳过该输入值。
宽度:用十进制整数指定输入的宽度(即字符数)
长度:长度格式符为l和h,l表示输入长整型数据(%ld)和双精度浮点数(%lf),h表示输入短整型数据。
注意:
scanf函数中没有精度控制,如:scanf("%5.2f",&a);是非法的。不能企图用些语句输入小数为2位的实数。
scanf中要求给出变量地址,如给出变量名则会出错,如scanf("%d",a);是非法的,应改为scanf("%d",&a);才是合法的。
在输入多个数据时,若格式控制串中没有非格式字符作输入数据之间的间隔则可用空格、TAB或回车作间隔。C编译器在碰到空格、TAB、回车或非法数据(如对"%d"输入12A时,A即为非法数据)时即认为该数据结束。
在输入字符数据时,若格式控制串中无非格式字符,则认为所有输入的字符均为有效字符。
如果格式控制串中有非格式字符则输入时也要输入该非格式字符。
如果输入的数据与输出的数据的类型不一致时,虽然编译能够通过,但结果将不正确。