学习第一个头文件stdio.h
使用标准输入输出库函数时要用到 “stdio.h”文件,因此源文件开头应有以下预编译命令:
1 #include<stdio.h>
stdio是standard input&outupt的意思。
1 #include"string.h"
那么#include "stdio.h" 与#include<stdio.h>有什么区别呢?
#include "stdio.h "
当要调用某个函数时先在用户自已编写的文件中查找,如果找不到再到库文件里去找,
而#include <stdio.h> 是直接到库文件里去找
所以如果是调用自己写的函数的话就用#include "stdio.h ",这种形式
而调用标准库函数的话就用#include <stdio.h> 这种形式,可以提高速度。
考虑到printf和scanf函数使用频繁,系统允许在使用这两个函数时可不加。
putchar 函数(字符输出函数)
putchar 函数是字符输出函数,其功能是在显示器上输出单个字符。其一般形式为:
putchar(字符变量);
getchar函数(键盘输入函数)
getchar函数的功能是从键盘上输入一个字符。其一般形式为:
getchar();
通常把输入的字符赋予一个字符变量,构成赋值语句。
使用getchar函数还应注意几个问题:
- getchar函数只能接受单个字符,输入数字也按字符处理。输入多于一个字符时,只接收第一个字符。
- 使用本函数前必须包含文件“stdio.h”。
输出函数printf()
printf函数称为格式输出函数,其关键字最末一个字母f即为“格式”(format)之意。其功能是按用户指定的格式,把指定的数据显示到显示器屏幕上。
1) 类型
类型字符用以表示输出数据的类型,其格式符和意义如下表所示:
格式字符 | 意义 |
---|---|
d | 以十进制形式输出带符号整数(正数不输出符号) |
o | 以八进制形式输出无符号整数(不输出前缀0) |
x,X | 以十六进制形式输出无符号整数(不输出前缀Ox) |
u | 以十进制形式输出无符号整数 |
f | 以小数形式输出单、双精度实数 |
e,E | 以指数形式输出单、双精度实数 |
g,G | 以%f或%e中较短的输出宽度输出单、双精度实数 |
c | 输出单个字符 |
s | 输出字符串 |
2) 标志
标志字符为 -、+、# 和空格四种,其意义下表所示:
标 志 | 意义 |
---|---|
- | 结果左对齐,右边填空格 |
+ | 输出符号(正号或负号) |
空格 | 输出值为正时冠以空格,为负时冠以负号 |
# |
对c、s、d、u类无影响; 对o类,在输出时加前缀o; 对x类,在输出时加前缀0x; 对e、g、f 类当结果有小数时才给出小数点。 |
3) 输出最小宽度
用十进制整数来表示输出的最少位数。若实际位数多于定义的宽度,则按实际位数输出,若实际位数少于定义的宽度则补以空格或0。
4) 精度
精度格式符以“.”开头,后跟十进制整数。本项的意义是:如果输出数字,则表示小数的位数;如果输出的是字符,则表示输出字符的个数;若实际位数大于所定义的精度数,则截去超过的部分。
5) 长度
长度格式符为h、l两种,h表示按短整型量输出,l表示按长整型量输出。
1 #include<stdio.h> 2 int main(void){ 3 int i=8; 4 printf("The raw value: i=%d\n", i); 5 printf("++i=%d \n++i=%d \n--i=%d \n--i=%d\n",++i,++i,--i,--i); 6 printf("%33s", "fdsfsdfewrwerewr"); 7 return 0; 8 }
使用printf函数时还要注意一个问题,那就是输出表列中的求值顺序。不同的编译系统不一定相同,可以从左到右,也可从右到左。Fedora 21 是按从右到左进行的。
再次实验单个printf的输出:
1 #include <stdio.h> 2 int main(void){ 3 int i=8; 4 printf("The raw value: i=%d\n", i); 5 printf("++i=%d\n", ++i); 6 printf("++i=%d\n", ++i); 7 printf("--i=%d\n", --i); 8 printf("--i=%d\n", --i); 9 return 0; 10 }
为什么结果会不同呢?
就是因为printf函数对输出表中各量求值的顺序是自右至左进行的。但是必须注意,求值顺序虽是自右至左,但是输出顺序还是从左至右,因此得到的结果是上述输出结果。
提示:这里的左边和右边指的是整体左边(格式控制字符串)和整体右边。
输入函数scanf()
scanf函数的一般形式为:
scanf(“格式控制字符串”, 地址表列);
其中,格式控制字符串的作用与printf函数相同,但不能显示非格式字符串,也就是不能显示提示字符串。地址表列中给出各变量的地址。地址是由地址运算符“&”后跟变量名组成的。
在C语言中,使用了地址这个概念,这是与其它语言不同的。 应该把变量的值和变量的地址这两个不同的概念区别开来。变量的地址是C编译系统分配的,用户不必关心具体的地址是多少。
格式字符串
格式字符串的一般形式为:
%[*][输入数据宽度][长度]类型
其中有方括号[]的项为任选项。各项的意义如下。
1) 类型
表示输入数据的类型,其格式符和意义如下表所示。
格式 | 字符意义 |
---|---|
d | 输入十进制整数 |
o | 输入八进制整数 |
x | 输入十六进制整数 |
u | 输入无符号十进制整数 |
f或e | 输入实型数(用小数形式或指数形式) |
c | 输入单个字符 |
s | 输入字符串 |
2) “*”符
用以表示该输入项,读入后不赋予相应的变量,即跳过该输入值。如:
- scanf("%d %*d %d",&a,&b);
当输入为:1 2 3时,把1赋予a,2被跳过,3赋予b。
宽度
用十进制整数指定输入的宽度(即字符数)。例如:
1 scanf("%5d",&a);
输入12345678只把12345赋予变量a,其余部分被截去。
长度
长度格式符为l和h,l表示输入长整型数据(如%ld)和双精度浮点数(如%lf)。h表示输入短整型数据。
使用scanf函数还必须注意以下几点:
- scanf函数中没有精度控制,如:scanf("%5.2f",&a);是非法的。不能企图用此语句输入小数为2位的实数。
- scanf中要求给出变量地址,如给出变量名则会出错。如 scanf("%d",a);是非法的,应改为scnaf("%d",&a);才是合法的。
- 在输入多个数值数据时,若格式控制串中没有非格式字符作输入数据之间的间隔则可用空格,TAB或回车作间隔。C编译在碰到空格,TAB,回车或非法数据(如对“%d”输入“12A”时,A即为非法数据)时即认为该数据结束。
- 在输入字符数据时,若格式控制串中无非格式字符,则认为所有输入的字符均为有效字符。