配色: 字号:
C程序课件第3章类型
2012-04-24 | 阅:  转:  |  分享 
  
C程序设计第三章数据类型、运算符与表达式一、C语言的数据类型二、整型量三、实型量四、字符型量五、变量的初值和类型转换六、
基本运算符和表达式七、小结复合赋值符这种写法,对初学者可能不习惯,但十分有利于编译处理,能提高编译效率并产生质量较高的
目标代码。C、逗号运算符C语言中逗号“,”也是一种运算符,称为逗号运算符。其功能是把两个表达式连接起来组成一个表达
式,称为逗号表达式。其一般形式为:表达式1,表达式2其求值过程是分别求两个表达式的值,并以表达式2的值作为整个逗
号表达式的值。例EX3_5voidmain(){ chara,b;a=‘x’;b=‘y’;/a,b被说明为字符变
量并赋予字符值/ a=a-32;b=b-32; /把小写字母换成大 写字母/ pri
ntf("%c,%c\n%d,%d\n",a,b,a,b); /以整型和字符型输出/}字符串常量是由一对双
引号括起的字符序列。例如:“CHINA”,“Cprogram:”,“$12.5”等都是合法的字符串常量。字
符串常量和字符常量是不同的量。它们之间主要有以下区别:4、字符串常量(1)字符常量由单引号括起来,字符串常量由双引号括
起来;(2)字符常量只能是单个字符,字符串常量则可以含一个或多个字符;(3)可以把一个字符常量赋予一个字符变量
,但不能把一个字符串常量赋予一个字符变量。在C语言中没有相应的字符串变量。但是可以用一个字符数组来存放一个字符串常量;在数组一章内
予以介绍。(4)字符常量占一个字节的内存空间。字符串常量占的内存字节数等于字符串中字节数加1。增加的一个字节中存放字符"
\0"(ASCII码为0即NULL)。这是字符串结束的标志。例如,字符串"Cprogram"在内存中所占的字节为:Cprog
ram\0。字符常量''a''和字符串常量"a"虽然都只有一个字符,但在内存中的情况是不同的。''a''在内存中占一个字节,可表
示为:a"a"在内存中占二个字节,可表示为:a\0符号常量在C语言中,可以用一个标识符来表示一个常量,称之为符号
常量。符号常量在使用之前必须先定义,其一般形式为: #define标识符常量字符串其中#define也是一条预
处理命令(预处理命令都以#开头),称为宏定义命令(在第九章预处理程序中将进一步介绍),其功能是把该标识符定义为其后的常量值。一经定
义,以后在程序中所有出现该标识符的地方均代之以该常量值。习惯上符号常量的标识符用大写字母,变量标识符用小写字母,以示区别。5、
符号常量例EX3_6符号常量的使用#definePI3.14159 /由宏定义命令定义PI为3.14159/v
oidmain(){ floats,r; r=5;s=PIrr; /s,r定义为实数5=>r,PIr
r=>s/ printf("s=%f\n",s);}1、变量赋初值在程序中常常需要对变量赋初值,以便使用变量。
语言程序中可有多种方法,在定义时赋以初值的方法,这种方法称为初始化。在变量说明中赋初值的一般形式为:类型说明符变量1
=值1,变量2=值2,……;变量名变量地址变量值存储单元说明:A、变量的类型说明符和其后的变量,是一个定义
过程,以便为说明的变量分配相应的存储单元(2、4,8字节);B、将值赋予已定义的变量,是取变量存储单元的地址,并将该值存放到指
定的存储单元中。形象地说:<值>=><变量>即表示为如下形式:变量地址为存储单元的首地址,箭头是一个指向关系,找
到变量的地址,即可以进行数据的存(写入)和取(读出)。例如: inta=5,b=5,c=5; floatx=3.2,
y=3f,z=0.75; charch1=''K'',ch2=''P'';应注意,在说明中不允许连续赋值, 如 inta=b=
c=5;是不合法的。例如给变量赋值并输出voidmain(){ inta=3,b,c=5; b=a+c; pri
ntf("a=%d,b=%d,c=%d\n",a,b,c);}变量的数据类型是可以转换的。转换的方法有两种,一种是自动转
换,一种是强制转换。2、变量类型的转换1)、自动转换:自动转换发生在不同数据类型的量混合运算时,由编译系统自动完成。
自动转换遵循以下规则:A、若参与运算量的类型不同,则先转换成同一类型,然后进行运算。B、转换按数据长度
增加的方向进行,以保证精度不降低。如int型和long型运算时,先把int量转成long型后再进行运算。C、所有的浮点运
算都是以双精度进行的,即使仅含float单精度量运算的表达式,也要先转换成double型,再作运算。D、char型和sh
ort型参与运算时,必须先转换成int型。E、在赋值运算中,赋值号两边量的数据类型不同时,赋值号右边量的类型将转换为左边
量的类型。如果右边量的数据类型长度左边长时,将丢失一部分数据,这样会降低精度,丢失的部分按四舍五入向前舍入。图3.10(P54)表
示了类型自动转换的规则。例EX3_7数据类型转换voidmain(){ floatPI=3.14159; int
s,r=5; s=rrPI; printf("s=%d\n",s);}本例程序中,PI为实型;s,r为整型。在
执行s=rrPI语句时,r和PI都转换成double型计算,结果也为double型。但由于s为整型,故赋值结果仍为整型,舍去
了小数部分。强制类型转换是通过类型转换运算来实现的。其一般形式为:(类型说明符)(表达式)其功能是把表
达式的运算结果强制转换成类型说明符所表示的类型。例如:(float)a把a转换为实型,(int)(x+y)把x+y的结果
转换为整型。在使用强制转换时应注意以下问题:2)、强制类型转换A、类型说明符和表达式都必须加括号(单个变量可以不加括号
),如把(int)(x+y)写成(int)x+y则成了把x转换成int型之后再与y相加了;B、无论是强制转换或是自动转换
,都只是为了本次运算的需要而对变量的数据长度进行的临时性转换,而不改变数据说明时对该变量定义的类型。例EX3_8数据类型的强制
转换voidmain(){ floatf=5.75; printf("(int)f=%d,f=%f\n",(int)f
,f);}将floatf强制转换成intf,floatf=5.75;printf("(int)f=%d,f
=%f\n",(int)f,f);本例表明,f虽强制转为int型,但只在运算中起作用,是临时的,而f本身的类型并不改变。因此,(
int)f的值为5(删去了小数)而f的值仍为5.75。C语言中运算符和表达式数量之多,在高级语言中是少见的。正是丰富
的运算符和表达式使C语言功能十分完善。这也是C语言的主要特点之一。1、运算符的种类、优先和结合性C语言的运算符不仅具有不同的
优先级,而且还有一个特点,就是它的结合性。在表达式中,各运算量参与运算的先后顺序不仅要遵守运算符优先级别的规定,还要受运算符结合性
的制约,以便确定是自左向右进行运算还是自右向左进行运算。这种结合性是其它高级语言的运算符所没有的,因此也增加了C语言的复杂性。
2)、关系运算符:用于比较运算。包括大于(>)、小于(<)、等于(==)、大于等于(>=)、小于等于(<=)和不等于(!=
)六种。1)、算术运算符:用于各类数值运算。包括加(+)、减(-)、乘()、除(/)、求余(或称模运算,%)、自增(+
+)、自减(--)共七种。3)、逻辑运算符:用于逻辑运算。包括与(&&)、或(||)、非(!)三种。4)、位操作
运算符:参与运算的量,按二进制位进行运算。包括位与(&)、位或(|)、位非(~)、位异或(^)、左移(<<)、右移(>>)六种。
10)、特殊运算符:有括号(),下标[],成员(->,.)等几种。5)、赋值运算符:用于赋值运算,分为简单赋值(
=)、复合算术赋值(+=,-=,=,/=,%=)和复合位运算赋值(&=,|=,^=,>>=,<<=)三类共十一种
。6)、条件运算符:这是一个三目运算符,用于条件求值(?:,)。7)、逗号运算符:用于把若干表达式组合成一
个表达式(,)。8)、指针运算符:用于取内容()和取地址(&)二种运算。9)、求字节数运算符:用于计算数据类型所
占的字节数(sizeof)。C语言中,运算符的运算优先级共分为15级。1级最高,15级最低。在表达式中,优先级较高的先于
优先级较低的进行运算(P375附录3)。C语言中各运算符的结合性分为两种,即左结合性(自左至右)和右结合性(自右至左)。
例如算术运算符的结合性是自左至右,即先左后右。如有表达式x-y+z则y应先与“-”号结合,执行x-y运算,然后再执行+z的运算。这
种自左至右的结合方向就称为“左结合性”。而自右至左的结合方向称为“右结合性”。最典型的右结合性运算符是赋值运算符。如x=y=z,由
于“=”的右结合性,应先执行y=z再执行x=(y=z)运算。C语言运算符中有不少为右结合性,应注意区别,以避免理解错误。2、优先
级和结合性A、加法运算符:"+"加法运算符为双目运算符,即应有两个量参与加法运算。如a+b,4+8等。具有右结合性。
B、减法运算符:"-"减法运算符为双目运算符。但"-"也可作负值运算符,此时为单目运算,如-x,-5等具有左结合性。C、
乘法运算符:""双目运算,具有左结合性。D、除法运算符:"/"双目运算具有左结合性。参与运算量均为整型时,结果也为整型,
舍去小数。如果运算量中有一个是实型,则结果为双精度实型。3、算术运算符和算术表达式1)、基本的算术运算符例EX3_9vo
idmain(){ printf("%d,%d\n",20/7,-20/7); printf("\n%f,%f\n",20.
0/7,-20.0/7);}双目运算具有左结合性。参与运算量均为整型时,结果也为整型,舍去小数。如果运算量中有一个是实
型,则结果为双精度实型。E、求余运算符(模运算符):“%”双目运算,具有左结合性。要求参与运算的量均为整型。求余运算的结
果等于两数相除后的余数。例EX3_10voidmain(){ printf("%d\n",100%3); }
双目运算,具有左结合性。求余运算符%要求参与运算的量均为整型。F、自增1,自减1运算符:自增1运算符记为"++",其
功能是使变量的值自增1。自减1运算符记为"--",其功能是使变量值自减1。自增1,自减1运算符均为单目运算,都具有右结合性。
有以下几种形式:++i,i自增1后再参与其它运算。--i,i自减1后再参与其它运算。i++,i参与运算后,i的值再自增
1。i--,i参与运算后,i的值再自减1。在理解和使用上容易出错的是i++和i--。特别是当它们出在较复杂的表达式或
语句中时,常常难于弄清,因此应仔细分析。例EX3_11自增或自减运算一voidmain(){ inti=8; pri
ntf("%d\n",++i); printf("%d\n",--i); printf("%d\n",i++); print
f("%d\n",i--); printf("%d\n",-i++); printf("%d\n",-i--);}8=>i,
i+1=>i,i-1=>i,i+1=>i,i-1=>i,i+1=>i,i-1=>i.第2行i加1后输出故
为9;第3行减1后输出故为8;第4行输出i为8之后再加1(为9);第5行输出i为9之后再减1(为8);第6行输出-8之后再加
1(为9);第7行输出-9之后再减1(为8)例EX3_12自增或自减运算二voidmain(){ inti=5,j=5
,p,q; p=(i++)+(i++)+(i++); q=(++j)+(++j)+(++j); printf("%d,%d,%
d,%d\n",p,q,i,j);}5=>i,5=>j,0=>p,0=>q.i+i+i=>p,i+1=>i,
i+1=>i,i+1=>ij+1=>j,j+1=>j,j+1=>j,j+j+j=>qp=(i++)+(i++
)+(i++);q=(++j)+(++j)+(++j);这个程序中,对p=(i++)+(i++)+(i++)应理解为
三个i相加,故P值为15。然后i再自增1三次相当于加3故i的最后值为8。而对于q的值则不然,q=(++j)+(++j)
+(++j)应理解为j先自增1,再参与运算,由于j自增1三次后值为8,三个8相加的和为24,j的最后值仍为8。对于自加
和自减运算有以下几点说明:(1)、表达式i++应当看成i=i+1,即i加1后再赋予i;同样i--也应表示为i=i-1,即
i减1再赋予i。(2)、为了避免运算中出现的岐义性,应在程序中适当增加一些中间变量,表明运算的中间过程,得到正确的结果。
上面两个例子可改写为:EX3_11_2voidmain(){ inti=8,a,b,c,d,e,f; a=
++i;b=--i;c=i++;d=i--;e=-i++;f=-i--; printf("%d\n",a);
printf("%d\n",b); printf("%d\n",c); printf("%d\n",d); printf
("%d\n",e); printf("%d\n",f);}EX3_12_2voidmain(){ inti=5,j
=5,p,q,a,b,c,d,e,f; a=i++;b=i++,c=i++; d=++j;e=++j;f=++
j; p=a+b+c;q=d+e+f; printf("%d,%d,%d,%d\n",p,q,i,j);}(3
)、C语言中有的运算符为一个字符,有的运算符由两个字符组成,在表达式中如何组合?如i+++j,是理解为(i++)+j,还是理解为i
+(++j)?C编译系统在处理时尽可能多地(自左向右)将若干个字符组成一个运算符(在处理标识符、关键字时也按同一原则处理),如i+
++j,应理解为(i++)+j,不能理解为i+(++j)。(4)、使用++和--运算符时,常会出现一些意想不到的副作用,
初学者要慎用。2)、算术表达式算术表达式是由常量、变量、函数和运算符组合起来的式子。一个表达式有一个值及其类型,它们等
于计算表达式所得结果的值和类型。表达式求值按运算符的优先级和结合性规定的顺序进行。单个的常量、变量、函数可以看作是表达式的特例。
由算术运算符和括号将变量连接起来的式子,称为算术表达式。以下是算术表达式的例子:a+b(a
2)/c(x+r)8-(a+b)/7++isin(x)+sin(y)(++i)
-(j++)+(k--)简单赋值运算符记为“=”。由“=”连接的式子称为赋值表达式。其一般形式为:变量=表达
式例如:x=a+bw=sin(a)+sin(b)y=i+++--jA、赋值运算符和赋值表达式赋值表达
式的功能是计算表达式的值再赋予左边的变量。赋值运算符具有右结合性。因此a=b=c=5可理解为a=(b=(c=5))
在其它高级语言中,赋值构成了一个语句,称为赋值语句。而在C中,把“=”定义为运算符,从而组成赋值表达式。凡是表达式可以出现的地方
均可出现赋值表达式。例如,式子x=(a=5)+(b=8)是合法的。它的意义是把5赋予a,8赋予b,再把a,b相加,和赋予
x,故x应等于13。在C语言中也可以组成赋值语句,按照C语言规定,任何表达式在其未尾加上分号就构成为语句。因此如x=8
;a=b=c=5;都是赋值语句,在前面各例中我们已大量使用过了。如果赋值运算符两边的数据类型不相同,系统将自动进行类
型转换,即把赋值号右边的类型换成左边的类型。具体规定如下:1)、实型赋予整型,舍去小数部分。前面的例3.8已经说明了这种
情况。2)、整型赋予实型,数值不变,但将以浮点形式存放,即增加小数部分(小数部分的值为0)。3)、字符型赋予整
型,由于字符型为一个字节,而整型为二个字节,故将字符的ASCII码值放到整型量的低八位中,高八位为0。4)、整型赋予字符
型,只把低八位赋予字符量。例EX3_13voidmain(){ inta,b=322;floatx,y=8.8
8;charc1=''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的低八位为0
1000010,即十进制66,按ASCII码对应于字符B)。在赋值符“=”之前加上其它二目运算符可构成复合赋值符。如+
=,-=,=,/=,%=,<<=,>>=,&=,^=,|=。B、复合赋值符及表达式
构成复合赋值表达式的一般形式为: 变量双目运算符=表达式它等效于变量=变量运算符表达式例
如: a+=5 等价于 a=a+5, x=y+7 等价于 x=x(y+7), r%=p 等价于 r=r%p。
数学系计算机系列课程课件之一本章要点3.1C语言的数据类型3.2整型量3.3实型量3.4字符型量
3.5变量的初值和类型转换3.6基本运算符和表达式在第一章中,我们已经看到程序中使用的各种变量都应预先加
以说明,即先说明,后使用。对变量的说明可以包括三个方面:数据类型、存储类型、作用域。在本章中,我们只介绍数据类型说明。其
它说明在以后各章中陆续介绍。所谓数据类型是按被说明量的性质,表示形式,占据存储空间的多少,构造特点来划分的。在C语言中,数据类型可
分为:基本数据类型,构造数据类型,指针类型,空类型四大类。基本数据类型最主要的特点是,其值不可以再分解为其它类型。也就是
说,基本数据类型是自我说明的。1、基本数据类型2、构造数据类型构造数据类型是根据已定义的一个或多个数据类型用构造的方
法来定义的。也就是说,一个构造类型的值可以分解成若干个“成员”或“元素”。每个“成员”都是一个基本数据类型或又是一个构造类型。在C
语言中,构造类型有以下几种:数组类型、结构类型、联合类型。指针是一种特殊的,同时又是具有重要作用的数据类型。其值用来表示
某个量在内存储器中的地址。虽然指针变量的取值类似于整型量,但这是两个类型完全不同的量,因此不能混为一谈。3、指针类型4、空类
型有一类函数,调用后并不需要向调用者返回函数值,这种函数可以定义为“空类型”。其类型说明符为void(P149)。在第
八章函数中还要详细介绍。在本章中,我们先介绍基本数据类型中的整型、浮点型和字符型。其余类型在以后各章中陆续介绍。
对于基本数据类型量,按其取值与否可改变又分为常量和变量两种。在程序执行过程中,其值不发生改变的量称为常量,取值可变的量称为变量
。它们可与数据类型结合起来分类。例如,可分为整型常量、整型变量、浮点常量、浮点变量、字符常量、字符变量、枚举常量、枚举变量。在程序
中,常量是可以不经说明而直接引用的,而变量则必须先说明后使用。整型量包括整型常量、整型变量。整型常量就是整常数。在C语
言中,使用的整常数有八进制、十六进制和十进制三种。1、整型常量八进制整常数:八进制整常数必须以0开头,即以0作为八进
制数的前缀。数码取值为0-7。八进制数通常是无符号数。以下各数是合法的八进制数: 015(十进制为13) 0101(
十进制为65) 0177777(十进制为65535)以下各数不是合法的八进制数: 256(无前缀0) 03A
2(包含了非八进制数码) -0127(出现了负号)十六进制整常数:十六进制整常数的前缀为0X或0x。其数码取值为0~9
,A~F或a~f。以下各数是合法的十六进制整常数: 0X2A(十进制为42)0XA0(十进制为160)
0XFFFF(十进制为65535)以下各数不是合法的十六进制整常数: 5A(无前缀0X) 0X3H
(含有非十六进制数码)十进制整常数:十进制整常数没有前缀。其数码为0-9。以下各数是合法的十进制整常数: 2
37-568655351627以下各数不是合法的十进制整常数: 023(不能有前导0)
23D(含有非十进制数码)在程序中是根据前缀来区分各种进制数的。因此在书写常数时不要把前缀弄错造成结果不正确。
在16位字长的机器上,整型常数的长度也为16位,因此表示的数的范围也是有限定的。十进制无符号整常数的范围为0-65535,有符
号数为-32768-+32767。八进制无符号数的表示范围为0-0177777。十六进制无符号数的表示范围为0X0-0XFFFF或
0x0-0xFFFF。如果使用的数超过了上述范围,就必须用长整型数来表示(整型常数的后缀)。长整型数是用后缀“L”或“l”来表示的
。例如:十进制长整常数158L(十进制为158)-358000L(十进制为-358000)八进制长整
常数012L(十进制为10)077L(十进制为63)0200000L(十进制为65536)十六进制长整常
数0X15L(十进制为21)0XA5L(十进制为165)0X10000L(十进制为65536)长整数15
8L和基本整常数158在数值上并无区别。但对158L,因为是长整型量,C编译系统将为它分配4个字节存储空间。而对158,因为是基
本整型,只分配2个字节的存储空间。因此在运算和输出格式上要予以注意,避免出错。无符号数也可用后缀表示,整型常数的无符号
数的后缀为“U”或“u”。例如:358u,0x38Au,235Lu均为无符号数。前缀,后缀可同时使用以表示各种类型
的数。如0XA5Lu表示十六进制无符号长整数A5,其十进制为165。(1)整型变量可分为以下几类:A、基本型:类型说
明符为int,在内存中占2个字节,其取值为基本整常数。B、短整型:类型说明符为shortint,所占字节和取值范围均与
基本型相同。C、长整型:类型说明符为longint或long,在内存中占4个字节,其取值为长整常数。D
、无符号型:类型说明符为unsigned。2、整型变量无符号型又可与上述三种类型匹配而构成:1)无符号
基本型类型说明符为: unsignedint或unsigned。2)无符号短整型类型说明符为: unsigne
dshort3)无符号长整型类型说明符为: unsignedlong各种无符号类型量所占的内存空间
字节数与相应的有符号类型量相同。但由于省去了符号位,故不能表示负数。下表列出了TurboC中各类整型量所分配的内存字
节数及数的表示范围。类型说明符 数的范围 分配字节数int -32768~32767 □□shortin
t -32768~32767 □□signedint -32768~32767 □□unsignedint
0~65535 □□longint -2147483648~2147483647 □□□□unsignedlong
0~4294967295 □□□□(2)、整型变量的说明变量说明的一般形式为:类型说明符变量名标识符,变量名标识符,
…;例如:inta,b,c; /a,b,c为整型变量/ longx,y; /x,y为长整型变量
/unsignedp,q; /p,q为无符号整型变量/在书写变量说明时,应注意以下几点
:1、允许在一个类型说明符后,说明多个相同类型的变量。各变量名之间用逗号间隔。类型说明符与变量名之间至少用一个空格间隔;
2、最后一个变量名之后必须以“;”号结尾;3、变量说明必须放在变量使用之前。一般放在函数体的开头部分。例
EX3_1输出不同类型数据运算的结果voidmain() /主函数说明为void,即不返回任何类型的值/{ long
x,y;inta,b,c,d; /x,y被定义为long型/ /a,b,c,d被
定义为int型/ x=5;y=6;a=7;b=8; /5=>x,6=>y,7=>a,8=>b/
c=x+a;d=y+b; /x+a=>c,y+b=>d/ printf("c=x+a=%d,d=y+b
=%d\n",c,d);/输出结果/}从程序中可以看到:x,y是长整型变量,a,b是基本整型变量。它们之
间允许进行运算,运算结果为长整型。但c,d被定义为基本整型,因此最后结果为基本整型。例EX3_1_2voidmain(
){ inta,b;longintc;longd; a=5;b=9; c=a+b-7;d=abc;c=
ddd;a=c-d; printf(“%d,%d,%ld,%ld\n”,a,b,c,d);}本例说明,不同类型
的量可以参与运算并相互赋值。其中的类型转换是由编译系统自动完成的。有关类型转换的规则将在以后介绍。1、实型常量实型也
称为浮点型。实型常量也称为实数或者浮点数。在C语言中,实数只采用十进制。它有二种形式:十进制数形式和指数形式。(1)十进
制数形式:由数码0~9和小数点组成。例如:0.0,.25,5.789,0.13,5.0,300.,-267.8230等均为合法的
实数。(2)指数形式:由十进制数,加阶码标志“e”或“E”以及阶码(只能为整数,可以带符号)组成。其一般形式为:aE
n(a为十进制数,n为十进制整数)其值为a×10n如:2.1E5(等于2.1×105),3.7E-2(等于3.7×10
-2),0.5E7(等于0.5×107),-2.8E-2(等于-2.8×10-2);以下不是合法的实数:345(无
小数点),E7(阶码标志E之前无数字),53.-E3(负号位置不对),2.7E(无阶码)。实型变量分为两类:单
精度型和双精度型,其类型说明符为float单精度说明符,double双精度说明符。在TurboC中单精度型占4个字节(32位
)内存空间,其数值范围为3.4E-38-3.4E+38,只能提供七位有效数字。双精度型占8个字节(64位)内存空间,其数值范围为
1.7E-308-1.7E+308,可提供16位有效数字。2、实型变量实型变量说明的格式和书写规则与整型相同。
实型变量说明的一般形式为:类型说明符变量名标识符,变量名标识符,…;例如:floatx,y;(x
,y为单精度实型量),doublea,b,c;(a,b,c为双精度实型量),实型常数不分单、双精度,都按双精度double型
处理。例EX3_2输出两个不同类型的数值voidmain(){ floata;doubleb; a=3333
3.33333;b=33333.333333333333; printf("a=%fb=%f\n",a,b);}此程
序说明float、double的不同:float a□□□□ 33333.33333=>adouble b□□□□□□
□□ 33333.333333333333=>b显示程序结果:a=33333.33b=33333.333333例
EX3_2_2整型、实型两种数据混合运算voidmain(){ inta=32;floatb;doubled;
b=12345678;d=b100; d=d+a;d=d+58.123456; printf(“%d,%10.2f
,%15.6f\n”,a,b,d);}字符型量包括字符常量和字符变量。1、字符常量字符常量是用单引号括起来的一个
字符。例如‘a’,‘b’,‘=’,‘+’,‘?’都是合法字符常量。在C语言中,字符常量有以下特点:(
1)字符常量只能用单引号括起来,不能用双引号或其它括号;(2)字符常量只能是单个字符,不能是字符串;(3)字符
可以是字符集中任意字符。但数字被定义为字符型之后就不能参与数值运算。如''5''和5是不同的。''5''是字符常量,不能参与运算。
转义字符是一种特殊的字符常量。转义字符以反斜线“\”开头,后跟一个或几个字符。转义字符具有特定的含义,不同于字符原有
的意义,故称“转义”字符。例如,在前面各例题printf函数的格式串中用到的“\n”就是一个转义字符,其意义是“回车换行
”。转义字符主要用来表示那些用一般字符不便于表示的控制代码。2、转义字符常用的转义字符及其含义转义字符
转义字符的意义 \n 回车换行 \t 横向跳到下一制表位置 \v 竖向跳格 \b 退格 \r 回车
\f 走纸换页 \\ 反斜线符"\" \'' 单引号符 \a 鸣铃 \ddd 1-3位八进制数所代表
的字符 \xhh 1-2位十六进制数所代表的字符一般说,C语言字符集中的任何一个字符均可用转义字符来表示。表3.3(P4
8)中的\ddd和\xhh正是为此而提出的。ddd和hh分别为八进制和十六进制的ASCII代码。如\101表示字母"A",\102表示字母"B",\134表示反斜线,\X0A表示换行等。例EX3_3转义字符的使用。voidmain(){ inta,b,c;a=5;b=6;c=7; printf("%d\n\t%d%d\n%d%d\t\b%d\n", a,b,c,a,b,c);}此程序练习转义字符的使用,程序在第一列输出a值5之后就是“\n”,故回车换行;接着又是“\t”,于是跳到下一制表位置(设制表位置间隔为8),再输出b值6;空二格再输出c值7后又是"\n",因此再回车换行;再空二格之后又输出a值5;再空三格又输出b的值6;再次后"\t"跳到下一制表位置(与上一行的6对齐),但下一转义字符“\b”又使退回一格,故紧挨着6再输出c值7。字符变量的取值是字符常量,即单个字符。字符变量的类型说明符是char。字符变量类型说明的格式和书写规则都与整型变量相同。字符变量说明的一般形式为:类型说明符变量名标识符,变量名标识符,…;3、字符变量例如:chara,b;每个字符变量被分配一个字节的内存空间,因此只能存放一个字符。字符值是以ASCII码的形式存放在变量的内存单元之中的。如x的十进制ASCII码是120,y的十进制ASCII码是121。对字符变量a,b赋予''x''和''y''值:a=''x'';b=''y'';实际上是在a,b两个单元内存放120和121的二进制代码:a:01111000,b:01111001。所以也可以把它们看成是整型量。C语言允许对整型变量赋以字符值,也允许对字符变量赋以整型值。在输出时,允许把字符变量按整型量输出,也允许把整型量按字符量输出。整型量为二字节量,字符量为单字节量,当整型量按字符型量处理时,只有低八位字节参与处理。例EX3_4输出字符型和整型数值voidmain(){ chara,b;a=120;b=121; printf("%c,%c\n%d,%d\n",a,b,a,b);}a□ b□ 120=>a,121=>b显示程序结果:a,b,120,121
献花(0)
+1
(本文系紫霄书屋首藏)