学习第一个头文件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函数还应注意几个问题:

  1. getchar函数只能接受单个字符,输入数字也按字符处理。输入多于一个字符时,只接收第一个字符。
  2. 使用本函数前必须包含文件“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) “*”符
用以表示该输入项,读入后不赋予相应的变量,即跳过该输入值。如:

  1. 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函数还必须注意以下几点:

    1. scanf函数中没有精度控制,如:scanf("%5.2f",&a);是非法的。不能企图用此语句输入小数为2位的实数。
    2. scanf中要求给出变量地址,如给出变量名则会出错。如 scanf("%d",a);是非法的,应改为scnaf("%d",&a);才是合法的。
    3. 在输入多个数值数据时,若格式控制串中没有非格式字符作输入数据之间的间隔则可用空格,TAB或回车作间隔。C编译在碰到空格,TAB,回车或非法数据(如对“%d”输入“12A”时,A即为非法数据)时即认为该数据结束。
    4. 在输入字符数据时,若格式控制串中无非格式字符,则认为所有输入的字符均为有效字符。

 

posted on 2015-05-13 07:09  liujie037  阅读(554)  评论(0编辑  收藏  举报

导航