友情提示:如果本网页打开太慢或显示不完整,请尝试鼠标右键“刷新”本网页!
富士康小说网 返回本书目录 加入书签 我的书架 我的书签 TXT全本下载 『收藏到我的浏览器』

C语言设计-第5部分

快捷操作: 按键盘上方向键 ← 或 → 可快速上下翻页 按键盘上的 Enter 键可回到本书目录页 按键盘上方向键 ↑ 可回到本页顶部! 如果本书没有阅读完,想下次继续接着阅读,可使用上方 "收藏到我的浏览器" 功能 和 "加入书签" 功能!


量。
【例 3。18】
main(){
  int a;b=322;
  float x;y=8。88;
  char c1='k';c2;
    a=y;
  x=b;
    a=c1;
    c2=b;
  printf(〃%d;%f;%d;%c〃;a;x;a;c2);
 }

本例表明了上述赋值运算中类型转换的规则。a 为整型,赋予实型量 y 值 8。88 后只取整
数 8。x 为实型,赋予整型量 b 值 322, 后增加了小数部分。字符型量 c1 赋予 a 变为整型,
整型量 b 赋予 c2 后取其低八位成为字符型(b 的低八位为 01000010,即十进制 66,按 ASCII
码对应于字符 B)。
3。 复合的赋值运算符
在 赋 值 符 “ = ” 之 前 加 上 其 它 二 目 运 算 符 可 构 成 复 合 赋 值 符 。 如 +=;…=;*=; /
=;%=;=;&=;^=;|=。
构成复合赋值表达式的一般形式为:
变量 双目运算符=表达式
它等效于
变量=变量 运算符 表达式
例如:
        a+=5            等价于 a=a+5
    x*=y+7    等价于 x=x*(y+7)
        r%=p            等价于 r=r%p
复合赋值符这种写法,对初学者可能不习惯,但十分有利于编译处理,能提高编译效
率并产生质量较高的目标代码。
3。10 逗号运算符和逗号表达式
在C语言中逗号“,”也是一种运算符,称为逗号运算符。 其功能是把两个表达式连接

谭浩强      C 语言程序设计               2001 年 5 月 1 日
起来组成一个表达式, 称为逗号表达式。
其一般形式为:
表达式 1,表达式 2
其求值过程是分别求两个表达式的值,并以表达式 2 的值作为整个逗号表达式的值。
【例 3。19】
main(){
  int a=2;b=4;c=6;x;y;
  y=(x=a+b);(b+c);
  printf(〃y=%d;x=%d〃;y;x);


本例中,y 等于整个逗号表达式的值,也就是表达式 2 的值,x 是第一个表达式的值。
对于逗号表达式还要说明两点:
1) 逗号表达式一般形式中的表达式 1 和表达式 2 也可以又是逗号表达式。
例如:
表达式 1,(表达式 2,表达式 3)
形成了嵌套情形。因此可以把逗号表达式扩展为以下形式:
表达式 1,表达式 2,…表达式 n
整个逗号表达式的值等于表达式 n 的值。
2) 程序中使用逗号表达式,通常是要分别求逗号表达式内各表达式的值,并不一定
要求整个逗号表达式的值。
并不是在所有出现逗号的地方都组成逗号表达式,如在变量说明中,函数参数表中逗号
只是用作各变量之间的间隔符。
3。11 小结
3。11。1 C的数据类型
基本类型,构造类型,指针类型,空类型
3。11。2 基本类型的分类及特点

字符型
基本整型
短整型
长整型
无符号型
无符号长整型
单精度实型
双精度实型

类型说明符
char
int
short int
long int
unsigned
unsigned long
float
double

字节
1
2
2
4
2
4
4
8

数值范围
C 字符集
…32768~32767
…32768~32767
…214783648~214783647
0~65535
0~4294967295
3/4E…38~3/4E+38
1/7E…308~1/7E+308


3。11。3 常量后缀
        L 或 l    长整型
        U 或 u   无符号数
F 或 f    浮点数
3。11。4 常量类型

谭浩强      C 语言程序设计               2001 年 5 月 1 日

整数,长整数,无符号数,浮点数,字符,字符串,符号常数,转义字符。
3。11。5 数据类型转换
?u33258X动转换:在不同类型数据的混合运算中,由系统自动实现转换,由少字节类型向多字节
类型转换。不同类型的量相互赋值时也由系统自动进行转换,把赋值号右边的类型转换为左
边的类型。
?u24378X制转换:由强制转换运算符完成转换。
3。11。6 运算符优先级和结合性
一般而言,单目运算符优先级较高,赋值运算符优先级低。算术运算符优先级较高,关
系和逻辑运算符优先级较低。多数运算符具有左结合性,单目运算符、三目运算符、赋值运
算符具有右结合性。
3。11。7 表达式
表达式是由运算符连接常量、变量、函数所组成的式子。 每个表达式都有一个值和类
型。表达式求值按运算符的优先级和结合性所规定的顺序进行。


谭浩强      C 语言程序设计               2001 年 5 月 1 日
4 最简单的 C 程序设计—顺序程序设计
    从程序流程的角度来看,程序可以分为三种基本结构, 即顺序结构、分支结构、循环
结构。 这三种基本结构可以组成所有的各种复杂程序。C语言提供了多种语句来实现这些
程序结构。 本章介绍这些基本语句及其在顺序结构中的应用,使读者对C程序有一个初步
的认识, 为后面各章的学习打下基础。
4。1 C语句概述
C程序的结构:
C程序

源程序文件1

源程序文件2

源程序文件n

预 处 理 命 令

全 局 变 量 声 明
函 数 首 部

函 数 1

函 数 体

函 数 n

局 部 变 量 声 明

执 行 语 句

C程序的执行部分是由语句组成的。 程序的功能也是由执行语句实现的。
C 语句可分为以下五类:
1) 表达式语句
2) 函数调用语句
3) 控制语句
4) 复合语句
5) 空语句
1。 表达式语句:表达式语句由表达式加上分号“;”组成。
其一般形式为:
    表达式;
执行表达式语句就是计算表达式的值。
例如:


    x=y+z;  赋值语句;

谭浩强      C 语言程序设计               2001 年 5 月 1 日

    y+z;    加法运算语句,但计算结果不能保留,无实际意义;
    i++;    自增 1 语句,i 值增 1。
2。 函数调用语句:由函数名、实际参数加上分号“;”组成。
其一般形式为:
    函数名(实际参数表);
执行函数语句就是调用函数体并把实际参数赋予函数定义中的形式参数,然后执行
被调函数体中的语句,求取函数值 (在后面函数中再详细介绍) 。
例如:
printf(〃C Program〃);调用库函数,输出字符串。
3。 控制语句:控制语句用于控制程序的流程, 以实现程序的各种结构方式。它们由特定
的语句定义符组成。C语言有九种控制语句。 可分成以下三类:
1) 条件判断语句:if 语句、switch 语句;
2) 循环执行语句:do while 语句、while 语句、for 语句;
3) 转向语句:break 语句、goto 语句、continue 语句、return 语句。
4。 复合语句:把多个语句用括号{}括起来组成的一个语句称复合语句。
在程序中应把复合语句看成是单条语句,而不是多条语句。
例如:
    { x=y+z;
      a=b+c;
      printf(“%d%d”,x,a);
     }
是一条复合语句。
复合语句内的各条语句都必须以分号“;”结尾,在括号“}”外不能加分号。
5。 空语句:只有分号“;”组成的语句称为空语句。空语句是什么也不执行的语句。在程
序中空语句可用来作空循环体。
例如
    while(getchar()!='n')
    ;
本语句的功能是,只要从键盘输入的字符不是回车则重新输入。
这里的循环体为空语句。
4。2 赋值语句
赋值语句是由赋值表达式再加上分号构成的表达式语句。
其一般形式为:
    变量=表达式;
赋值语句的功能和特点都与赋值表达式相同。 它是程序中使用最多的语句之一。
在赋值语句的使用中需要注意以下几点:
1。 由于在赋值符“=”右边的表达式也可以又是一个赋值表达式,
因此,下述形式
        变量=(变量=表达式);
是成立的,从而形成嵌套的情形。
其展开之后的一般形式为:


谭浩强      C 语言程序设计               2001 年 5 月 1 日
        变量=变量=…=表达式;
例如:
    a=b=c=d=e=5;
按照赋值运算符的右接合性,因此实际上等效于:
    e=5;
    d=e;
    c=d;
    b=c;
    a=b;
2。 注意在变量说明中给变量赋初值和赋值语句的区别。
给变量赋初值是变量说明的一部分,赋初值后的变量与其后的其它同类变量之
间仍必须用逗号间隔,而赋值语句则必须用分号结尾。
例如:
    int a=5;b;c;
3。 在变量说明中,不允许连续给多个变量赋初值。
如下述说明是错误的:
      int a=b=c=5
必须写为
      int a=5;b=5;c=5;
而赋值语句允许连续赋值。
4。 注意赋值表达式和赋值语句的区别。
赋值表达式是一种表达式,它可以出现在任何允许表达式出现的地方,而赋值
语句则不能。
下述语句是合法的:
      if((x=y+5)》0) z=x;
语句的功能是,若表达式 x=y+5 大于 0 则 z=x。
下述语句是非法的:
      if((x=y+5;)》0) z=x;
因为 x=y+5;是语句,不能出现在表达式中。
4。3 数据输入输出的概念及在 C 语言中的实现
1) 所谓输入输出是以计算机为主体而言的。
2) 本章介绍的是向标准输出设备显示器输出数据的语句。
3) 在C语言中,所有的数据输入/输出都是由库函数完成的。 因此都是函数语句。
4) 在使用C语言库函数时,要用预编译命令
#include
将有关“头文件”包括到源文件中。
使用标准输入输出库函数时要用到 “stdio。h”文件,因此源文件开头应有以下预
编译命令:
#include《 stdio。h 》

#include ”stdio。h”
stdio 是 standard input &outupt 的意思。

谭浩强      C 语言程序设计               2001 年 5 月 1 日
5) 考虑到 printf 和 scanf 函数使用频繁,系统允许在使用这两个函数时可不加
#include《 stdio。h 》

#include ”stdio。h”
4。4 字符数据的输入输出
4。4。1 putchar  函数(字符输出函数)
putchar 函数是字符输出函数, 其功能是在显示器上输出单个字符。
其一般形式为:
putchar(字符变量)
例如:
    putchar('A');    (输出大写字母 A)
    putchar(x);      (输出字符变量 x 的值)
putchar(‘101’); (也是输出字符 A)
putchar('n');   (换行)
对控制字符则执行控制功能,不在屏幕上显示。
使用本函数前必须要用文件包含命令:
#include

#include “stdio。h”
【例 4。1】输出单个字符。
#include
main(){
  char a='B';b='o';c='k';
  putchar(a);putchar(b);putchar(b);putchar(c);putchar('t');
  putchar(a);putchar(b);
  putchar('n');
  putchar(b);putchar(c);
 }

4。4。2 getchar 函数(键盘输入函数)
getchar 函数的功能是从键盘上输入一个字符。
其一般形式为:
    getchar();
通常把输入的字符赋予一个字符变量,构成赋值语句,如:
    char c;
        c=getchar();

【例 4。2】输入单个字符。
#include
void main(){
  char c;
  printf(〃input a charactern〃);
  c=getchar();
  putchar(c);


使用 getchar 函数还应注意几个问题:

谭浩强      C 语言程序设计               2001 年 5 月 1 日

1) getchar 函数只能接受单个字符,输入数字也按字符处理。输入多于一个字符时,只接
收第一个字符。
2) 使用本函数前必须包含文件“stdio。h”。
3) 在 TC 屏幕下运行含本函数程序时,将退出 TC 屏幕进入用户屏幕等待用户输入。输入
完毕再返回 TC 屏幕。
4) 程序最后两行可用下面两行的任意一行代替:
putchar(getchar());
printf(“%c”;getchar());
4。5 格式输入与输出
4。5。1 printf 函数(格式输出函数)
printf 函数称为格式输出函数,其关键字最末一个字母 f 即为“格式”(format)之意。
其功能是按用户指定的格式,把指定的数据显示到显示器屏幕上。在前面的例题中我们已多
次使用过这个函数。
1。 printf 函数调用的一般形式
printf 函数是一个标准库函数,它的函数原型在头文件“stdio。h”中。但作为一个特例,
不要求在使用 printf 函数之前必须包含 stdio。h 文件。
printf 函数调用的一般形式为:
printf(“格式控制字符串”,输出表列)
其中格式控制字符串用于指定输出格式。格式控制串可由格式字符串和非格式字符
串两种组成。格式字符串是以%开头的字符串,在%后面跟有各种格式字符,以说明输出
数据的类型、形式、长度、小数位数等。如:
“%d”表示按十进制整型输出;
“%ld”表示按十进制长整型输出;
“%c”表示按字符型输出等。
非格式字符串在输出时原样照印,在显示中起提示作用。
输出表列中给出了各个输出项,要求格式字符串和各输出项在数量和类型上应该一
一对应。
【例 4。3】
main()



  int a=88;b=89;
  printf(〃%d %dn〃;a;b);
  printf(〃%d;%dn〃;a;b);
  printf(〃%c;%cn〃;a;b);
  printf(〃a=%d;b=%d〃;a;b);



谭浩强      C 语言程序设计               2001 年 5 月 1 日

本例中四次输出了 a;b 的值,但由于格式控制串不同,输出的结果也不相同。第四行的
输出语句格式控制串中,两格式串%d 之间加了一个空格(非格式字符),所以输出的 a;b 值
之间有一个空格。第五行的 printf 语句格式控制串中加入的是非格式字符逗号, 因此输出
的 a;b 值之间加了一个逗号。第六行的格式串要求按字符型输出 a;b 值。第七行中为了提
示输出结果又增加了非格式字符串。
2。 格式字符串
在 Turbo C 中格式字符串的一般形式为:
'标志''输出最小宽度''。精度''长度'类型
  其中方括号''中的项为可选项。
各项的意义介绍如下:
1) 类型:类型字符用以表示输出数据的类型,其格式符和意义如下表所示:

格式字符
d
o
x;X
u
f
e;E
g;G
c
s

意            义
以十进制形式输出带符号整数(正数不输出符号)
以八进制形式输出无符号整数(不输出前缀 0)
以十六进制形式输出无符号整数(不输出前缀 Ox)
以十进制形式输出无符号整数
以小数形式输出单、双精度实数
以指数形式输出单、双精度实数
以%f 或%e 中较短的输出宽度输出单、双精度实数
输出单个字符
输出字符串

2) 标志:标志字符为…、+、#、空格四种,其意义下表所示:
标 志 意         义




结果左对齐,右边填空格
输出符号(正号或负号)

空格 输出值为正时冠以空格,为负时冠以负号
对 c;s;d;u 类无影响;对 o 类;在输出时加前缀 o;对 x 类;在输出时
#
加前缀 0x;对 e;g;f 类当结果有小数时才给出小数点
3) 输出最小宽度:用十进制整数来表示输出的最少位数。若实际位数多于定义的宽度,
则按实际位数输出,若实际位数少于定义的宽度则补以空格或 0。
4) 精度:精度格式符以“。”开头,后跟十进制整数。本项的意义是:如果输出数字,
则表示小数的位数;如果输出的是字符,则表示输出字符的个数;若实际位数大于
所定义的精度数,则截去超过的部分。
5。长度:长度格式符为 h;l 两种,h 表示按短整型量输出,l 表示按长整型量输出。
【例 4。4】


main()

  int a=15;
  float b=123。1234567;
  double c=12345678。1234567;
  char d='p';

谭浩强      C 语言程序设计               2001 年 5 月 1 日

  printf(〃a=%d;%5d;%o;%xn〃;a;a;a;a);
  printf(〃b=%f;%lf;%5。4lf;%en〃;b;b;b;b);
  printf(〃c=%lf;%f;%8。4lfn〃;c;c;c);
  printf(〃d=%c;%8cn〃;d;d);
 }

    本例第七行中以四种格式输出整型变量 a 的值,其中“%5d ”要求输出宽度为 5,而 a
值为 15 只有两位故补三个空格。 第八行中以四种格式输出实型量 b 的值。其中“%f”和
“%lf ”格式的输出相同,说明“l”符对“f”类型无影响。“%5。4lf”指定输出宽度为 5,精度
为 4,由于实际长度超过 5 故应该按实际位数输出,小数位数超过 4 位部分被截去。第九行
输出双精度实数,“%8。4lf ”由于指定精度为 4 位故截去了超过 4 位的部分。第十行输出字
符量 d,其中“%8c ”指定输出宽度为 8 故在输出字符 p 之前补加 7 个空格。
使用 printf 函数时还要注意一个问题,那就是输出表列中的求值顺序。不同的编译系
统不一定相同,可以从左到右,也可从右到左。Turbo C 是按从右到左进行的。请看下面两
个例子:
【例 4。5】
main(){
  int i=8;
  printf(〃%dn%dn%dn%dn%dn%dn〃;++i;……i;i++;i……;…i++;…i……);


【例 4。6】
main(){
  int i=8;
  printf(〃%dn〃;++i);
  printf(〃%dn〃;……i);
  printf(〃%dn〃;i++);
  printf(〃%dn〃;i……);
printf(〃%dn〃;…i++);
  printf(〃%dn〃;…i……);


这两个程序的区别是用一个 printf 语句和多个 printf 语句输出。但从结果可以看出
是不同的。为什么结果会不同呢?就是因为 printf 函数对输出表中各量求值的顺序是自右
至左进行的。在第一例中,先对最后一项“…i……”求值,结果为…8;然后 i 自减 1 后为 7。 再


谭浩强      C 语言程序设计               2001 年 5 月 1 日
对“…i++”项求值得…7,然后 i 自增 1 后为 8。再对“i……”项求值得 8,然后 i 再自减 1 后为
7。再求“i++”项得 7,然后 i 再自增 1 后为 8。 再求“……i”项,i 先自减 1 后输出,输出值
为 7。 最后才求输出表列中的第一项“++i”,此时 i 自增 1 后输出 8。
但是必须注意,求值顺序虽是自右至左,但是输出顺序还是从左至右,因此得到的结果
是上述输出结果。
4。5。2 scanf 函数(格式输入函数)
scanf 函数称为格式输入函数,即按用户指定的格式从键盘上把数据输入到指定的变量
之中。
1。 scanf 函数的一般形式
scanf 函数是一个标准库函数,它的函数原型在头文件“stdio。h”中,与 printf 函数相
同,C语言也允许在使用 scanf 函数之前不必包含 stdio。h 文件。
scanf 函数的一般形式为:
scanf(“格式控制字符串”,地址表列);
其中,格式控制字符串的作用与 printf 函数相同,但不能显示非格式字符串,也就是
不能显示提示字符串。地址表列中给出各变量的地址。地址是由地址运算符“&”后跟变量名
组成的。
例如:
&a; &b
分别表示变量 a 和变量 b 的地址。
这个地址就是编译系统在内存中给 a;b 变量分配的地址。在C语言中,使用了地址这个
概念,这是与其它语言不同的。 应该把变量的值和变量的地址这两个不同的概念区别开来。
变量的地址是 C 编译系统分配的,用户不必关心具体的地址是多少。
变量的地址和变量值的关系如下:
在赋值表达式中给变量赋值,如:
    a=567
 则,a 为变量名,567 是变量的值,&a 是变量 a 的地址。
但在赋值号左边是变量名,不能写地址,而 scanf 函数在本质上也是给变量赋值,但要
求写变量的地址,如&a。 这两者在形式上是不同的。&是一个取地址运算符,&a 是一个表
达式,其功能是求变量的地址。
【例 4。7】
main(){
  int a;b;c;
  printf(〃input a;b;cn〃);
  scanf(〃%d%d%d〃;&a;&b;&c);
  printf(〃a=%d;b=%d;c=%d〃;a;b;c);


在本例中,由于 scanf 函数本身不能显示提示串,故先用 printf 语句在屏幕上输出提
示,请用户输入 a、b、c 的值。执行 scanf 语句,则退出 TC 屏幕进入用户屏幕等待用户输
入。用户输入 7  8  9 后按下回车键,此时,系统又将返回 TC 屏幕。在 scanf 语句的格式
串中由于没有非格式字符在“%d%d%d”之间作输入时的间隔,因此在输入时要用一个以上的

谭浩强      C 语言程序设计               2001 年 5 月 1 日
空格或回车键作为每两个输入数之间的间隔。如:
   7 8 9

7
  8
  9
2。 格式字符串
格式字符串的一般形式为:
%'*''输入数据宽度''长度'类型
其中有方括号''的项为任选项。各项的意义如下:
1) 类型:表示输入数据的类型,其格式符和意义如下表所示。

格式
d
o
x
u
f 或 e
c
s

字符意义
输入十进制整数
输入八进制整数
输入十六进制整数
输入无符号十进制整数
输入实型数(用小数形式或指数形式)
输入单个字符
输入字符串

2) “*”符:用以表示该输入项;读入后不赋予相应的变量,即跳过该输入值。
返回目录 上一页 下一页 回到顶部 1 0
快捷操作: 按键盘上方向键 ← 或 → 可快速上下翻页 按键盘上的 Enter 键可回到本书目录页 按键盘上方向键 ↑ 可回到本页顶部!
温馨提示: 温看小说的同时发表评论,说出自己的看法和其它小伙伴们分享也不错哦!发表书评还可以获得积分和经验奖励,认真写原创书评 被采纳为精评可以获得大量金币、积分和经验奖励哦!