C语言之数据类型-运算符-表达式
C语言的数据类型j] jZU v&M!\#D
在第一课中,我们已经看到程序中使用的各种变量都应预先加以说明,即先说明,后使用。对变量的说明可以包括三个方面:$jxfF x e M
·数据类型
·存储类型 MGO VpB7j;C;n
·作用域
在本课中,我们只介绍数据类型说明。其它说明在以后各章中陆续介绍。所谓数据类型是按被说明量的性质,表示形式,占据存储空间的多少,构造特点来划分的。在C语言中,数据类型可分为:基本数据类型,构造数据类型,指针类型,空类型四大类。8z9`t.?(PLy mD
9Ez%Up#vLkvt
1.基本数据类型r.\u,i?
基本数据类型最主要的特点是,其值不可以再分解为其它类型。也就是说,基本数据类型是自我说明的。H6~4qbl4Q CB
2.构造数据类型构造数据类型
Qa(YEm(HU!q
是根据已定义的一个或多个数据类型用构造的方法来定义的。也就是说,一个构造类型的值可以分解成若干个“成员”或“元素”。每个“成员”都是一个基本数据类型或又是一个构造类型。在C语言中,构造类型有以下几种:
·数组类型
·结构类型G4EF%^;Ubn(E @
·联合类型
@y@;|?$o/O(~
3.指针类型1H:H;j1S#[%tzV
8L2M z"Q*Y6EnD
指针是一种特殊的,同时又是具有重要作用的数据类型。其值用来表示某个量在内存储器中的地址。虽然指针变量的取值类似于整型量,但这是两个类型完全不同的量,因此不能混为一谈。4.空类型在调用函数值时,通常应向调用者返回一个函数值。这个返回的函数值是具有一定的数据类型的,应在函数定义及函数说明中给以说明,例如在例题中给出的max函数定义中,函数头为: int max(int a,int b);其中“int ”类型说明符即表示该函数的返回值为整型量。又如在例题中,使用了库函数 sin,由于系统规定其函数返回值为双精度浮点型,因此在赋值语句s=sin (x);中,s 也必须是双精度浮点型,以便与sin函数的返回值一致。所以在说明部分,把s说明为双精度浮点型。但是,也有一类函数,调用后并不需要向调用者返回函数值, 这种函数可以定义为“空类型”。其类型说明符为void。在第五章函数中还要详细介绍。在本章中,我们先介绍基本数据类型中的整型、浮点型和字符型。其余类型在以后各章中陆续介绍。/E/a8H T-zfpI-s
8U|GQZB$ll^A
对于基本数据类型量,按其取值是否可改变又分为常量和变量两种。在程序执行过程中,其值不发生改变的量称为常量,取值可变的量称为变量。它们可与数据类型结合起来分类。例如,可分为整型常量、整型变量、浮点常量、浮点变量、字符常量、字符变量、枚举常量、枚举变量。在程序中,常量是可以不经说明而直接引用的,而变量则必须先说明后使用。-j\J]5M#s5L@
s(B5FC;t)h1p-V
整型量yG(F5m9lk%c
整型量包括整型常量、整型变量。整型常量就是整常数。在C语言中,使用的整常数有八进制、十六进制和十进制三种。
整型常量,F I%s8My4[X
3}uGu!I;?)M4]
1.八进制整常数八进制整常数必须以0开头,即以0作为八进制数的前缀。数码取值为0~7。八进制数通常是无符号数。
以下各数是合法的八进制数: PU2N eYP's
015(十进制为13) 0101(十进制为65) 0177777(十进制为65535)k#ai'aO
以下各数不是合法的八进制数:
256(无前缀0) 03A2(包含了非八进制数码) -0127(出现了负号)vv$m4H%L?7Ul
xOK#q\oE'u [
2.十六进制整常数g2g7U*l(i+c
十六进制整常数的前缀为0X或0x。其数码取值为0~9,A~F或a~f。
以下各数是合法的十六进制整常数:
0X2A(十进制为42) 0XA0 (十进制为160) 0XFFFF (十进制为65535)
以下各数不是合法的十六进制整常数:
5A (无前缀0X) 0X3H (含有非十六进制数码)
3.十进制整常数
十进制整常数没有前缀。其数码为0~9。
以下各数是合法的十进制整常数::|'Uh3p2bX2H^K+S5G
237 -568 65535 1627
以下各数不是合法的十进制整常数:
023 (不能有前导0) 23D (含有非十进制数码)
C语言之数据类型-运算符-表达式
在程序中是根据前缀来区分各种进制数的。因此在书写常数时不要把前缀弄错造成结果不正确。4.整型常数的后缀在16位字长的机器上,基本整型的长度也为16位,因此表示的数的范围也是有限定的。十进制无符号整常数的范围为0~65535,有符号数为-32768~+32767。八进制无符号数的表示范围为0~0177777。十六进制无符号数的表示范围为0X0~0XFFFF或0x0~0xFFFF。如果使用的数超过了上述范围,就必须用长整型数来表示。长整型数是用后缀“L”或“l”来表示的。例如:(OV5I aO/kur%l;z十进制长整常数 158L (十进制为158) 358000L (十进制为-358000)G&y5h x,m {+X$h
八进制长整常数 012L (十进制为10) 077L (十进制为63) 0200000L (十进制为65536)
十六进制长整常数 0X15L (十进制为21) 0XA5L (十进制为165) 0X10000L (十进制为65536)
长整数158L和基本整常数158 在数值上并无区别。但对158L,因为是长整型量,C编译系统将为它分配4个字节存储空间。而对158,因为是基本整型,只分配2 个字节的存储空间。因此在运算和输出格式上要予以注意,避免出错。无符号数也可用后缀表示,整型常数的无符号数的后缀为“U”或“u”。例如: 358u,0x38Au,235Lu 均为无符号数。前缀,后缀可同时使用以表示各种类型的数。如0XA5Lu表示十六进制无符号长整数A5,其十进制为165。
6jby-@P
整型变量 ` wZ{icH ] f
整型变量可分为以下几类: SS1Z7^|)_6W|
1.基本型
类型说明符为int,在内存中占2个字节,其取值为基本整常数。;J N5oo.vG
2.短整量
类型说明符为short int或short'C110F1。所占字节和取值范围均与基本型相同。
3.长整型
类型说明符为long int或long ,在内存中占4个字节,其取值为长整常数。
4.无符号型
类型说明符为unsigned。%\'JgbI+L9D"U.K`y
无符号型又可与上述三种类型匹配而构成:
(1)无符号基本型 类型说明符为unsigned int或unsigned。] i|i2S%`*nti5s
(2)无符号短整型 类型说明符为unsigned short
(3)无符号长整型 类型说明符为unsigned long NE#aT3xC Q.l]
各种无符号类型量所占的内存空间字节数与相应的有符号类型量相同。但由于省去了符号位,故不能表示负数。 下表列出了Turbo C中各类整型量所分配的内存字节数及数的表示范围。
类型说明符 数的范围 分配字节数+}d*E n&g'U.y%W
int -32768~32767 ■■
short int -32768~32767 ■■
signed int -32768~32767 ■■
unsigned int 0~65535 ■■:gv,pH({4[#P5|
long int -2147483648~2147483647 ■■■■X;Q!x$kWW*P3M1G2M
unsigned long 0~4294967295 ■■■■c,k+KG0F
整型变量的说明
变量说明的一般形式为: 类型说明符 变量名标识符,变量名标识符,...; 例如:%y7r})w5s&o
int a,b,c; (a,b,c为整型变量)7~|7b3OF^
long x,y; (x,y为长整型变量)$b}W:ZEx~
unsigned p,q; (p,q为无符号整型变量)e1p$e7C-x]9O%F
3c;] hq;y,p]
在书写变量说明时,应注意以下几点:J4p3C"Z*@1bj
1.允许在一个类型说明符后,说明多个相同类型的变量。各变量名之间用逗号间隔。类型说明符与变量名之间至少用一个空格间隔。
2.最后一个变量名之后必须以“;”号结尾。
3.变量说明必须放在变量使用之前。一般放在函数体的开头部分。pP'F/EF
[Practice] //1int a,b;(@'P9M$y8yU
short int c;
short d=100;
a=d-20;
b=a+d;
c=a+b+d;
d=d-a+c-b;'Vtable
a,2,0
b,2,0
c,2,02UL9cNBs:m6x5|-jR
d,2,100K!Fw+q;uEL
of Vtable
'VupdateV _r^J5iHY,[:p
1,0;2,01\ R$n!IX ~o ^
3,0
4,100
1,80
2,180A5wj1[8iwB
3,360
4,200%M;ThQRRO}}
of Vupdate,~a/Swtb,x V U
of Practice
[Practice] //2int a=5;
int b=9;Jh%B?3OO5}
long int c;/f7u2WxN
long d; {~:sT}w2^
c=a+b-7;sv$g@R;A6h
d=a*b*c;
c=d*d*d;Q3~ o.|6J1^
a=c-d;'Vtablen;a[&XaK.O2@O&`
a,2,5
b,2,9!gc9{g%G rh5a1C)KH
c,4,0
d,4,0GB4VX]Z8L2v H!h7h.X
of Vtable
'Vupdate
1,5$f(]0\'uvU*u
2,9
3,0:ef6M@J
4,02~HZ#](oKm1n-a3a
3,7
4,315O/M+R6TPx/j9`\,Y\
3,31255875&d Ook4h1Mu
1,-5112(e)`"l!q,X
of Vupdate9TZ3B7Y$cCQ
of Practice
[Practice] //3int a=6,b=19;M W*p s,{{/j~a
unsigned int c;
int d;?OY9I#b B
c=a-b+7;x(F;V4\b(G `V2i$I_
d=b*c;
a=b+c+d;
b=-a;'Vtable q.z;m/sv}z
a,2,6
b,2,19
c,2,0
d,2,0n9^,[4x,O
of Vtable
'Vupdate6dC f+t6H
1,6;2,19
3,0 ?C;],] wyjs
4,0
3,65530
4,-114
1,-101
2,101d2k6M,U jB+z
of VupdateKx'PCS
of Practice1g Sl'iI-[Xo
void main(){ku0Qep)Lj
long x,y;*I^] f p2^1P
int a,b,c,d;
x=5;
y=6;yPt6?'Yt
a=7;
b=8;$}-e#UN \)J
c=x+a;GK!Pr&l%`
d=y+b;0t8N'E$uk*_x
printf("c=x+a=%d,d=y+b=%d\n",c,d);%G'N%]/k?.e
}3~S$w-s+Jy
将main说明为返回void,即不返回任何类型的值
x,y被定义为long型5FT]9{wa
a,b,c,d被定义为int型
5->x!j x@]5|8I?
6->y ~2bj(DZ'M
7->aS(d%T.|:{\iUE
8->b
x+a->c Z!Cb]&[9F4w+np
y+b->d
显示程序运行结果 of long x,y;
int a,b,c,d;
c=x+a;
d=y+b;
从程序中可以看到:x, y是长整型变量,a, b是基本整型变量。它们之间允许进行运算,运算结果为长整型。但c,d被定义为基本整型,因此最后结果为基本整型。本例说明,不同类型的量可以参与运算并相互赋值。其中的类型转换是由编译系统自动完成的。有关类型转换的规则将在以后介绍。
C语言之数据类型-运算符-表达式
实型量q.g W j*G#Wz
实型常量
实型也称为浮点型。实型常量也称为实数或者浮点数。在C语言中,实数只采用十进制。它有二种形式: 十进制数形式指数形式
1.十进制数形式Z7O4v1`BAw
由数码0~ 9和小数点组成。例如:0.0,.25,5.789,0.13,5.0,300.,-267.8230等均为合法的实数。a'} L-DP
2.指数形式5w Zxw5[y!h`k
由十进制数,加阶码标志“e”或“E”以及阶码(只能为整数,可以带符号)组成。其一般形式为a E n (a为十进制数,n为十进制整数)其值为 a*10,n 如: 2.1E5 (等于2.1*10,5), 3.7E-2 (等于3.7*10,)-2*) 0.5E7 (等于0.5*10,7), -2.8E-2 (等于-2.8*10,)-2*)以下不是合法的实数 345 (无小数点) E7 (阶码标志E之前无数字) -5 (无阶码标志) 53.-E3 (负号位置不对) 2.7E (无阶码)S^q!Y ~0w+k5X7H
标准C允许浮点数使用后缀。后缀为“f”或“F”即表示该数为浮点数。如356f和356.是等价的。例2.2说明了这种情况:8gy,y,oX]+j6lS
void main()4~4V4o"m[F d+^7b*e/B
{
printf("%f\n%f\n",356.,356f);W*?;Cn8^
}bhI#{ R"D ]6v7HID
void 指明main不返回任何值 利用printf显示结果 结束
5H N?:sN5t.G,r
实型变量 p4l,r8p{~l6RO
iM$^ pUK"S
实型变量分为两类:单精度型和双精度型,
其类型说明符为float 单精度说明符,double 双精度说明符。在Turbo C中单精度型占4个字节(32位)内存空间,其数值范围为3.4E-38~3.4E+38,只能提供七位有效数字。双精度型占8 个字节(64位)内存空间,其数值范围为1.7E-308~1.7E+308,可提供16位有效数字。
实型变量说明的格式和书写规则与整型相同。
例如: float x,y; (x,y为单精度实型量)jvC'wLaj~(p
double a,b,c; (a,b,c为双精度实型量) K-J!u7g?#|
实型常数不分单、双精度,都按双精度double型处理。)eW|4f9D mw,AC0D}|0I
void main()+X(TnjIclPZb
{om@1FQ0md[}
float a;@+@_P4Wi+j*wg-t
double b;