c语言运算符及其表达式教学内容文档格式.docx
《c语言运算符及其表达式教学内容文档格式.docx》由会员分享,可在线阅读,更多相关《c语言运算符及其表达式教学内容文档格式.docx(18页珍藏版)》请在冰豆网上搜索。
但是,也有一类函数,调用后并不需要向调用者返回函数值,这种函数可以定义为“空类型”。
其类型说明符为void。
在第五章函数中还要详细介绍。
在本章中,我们先介绍基本数据类型中的整型、浮点型和字符型。
其余类型在以后各章中陆续介绍。
对于基本数据类型量,按其取值是否可改变又分为常量和变量两种。
在程序执行过程中,其值不发生改变的量称为常量,取值可变的量称为变量。
它们可与数据类型结合起来分类。
例如,可分为整型常量、整型变量、浮点常量、浮点变量、字符常量、字符变量、枚举常量、枚举变量。
在程序中,常量是可以不经说明而直接引用的,而变量则必须先说明后使用。
整型量
整型量包括整型常量、整型变量。
整型常量就是整常数。
在C语言中,使用的整常数有八进制、十六进制和十进制三种。
整型常量
1.八进制整常数八进制整常数必须以0开头,即以0作为八进制数的前缀。
数码取值为0~7。
八进制数通常是无符号数。
以下各数是合法的八进制数:
015(十进制为13) 0101(十进制为65) 0177777(十进制为65535)
以下各数不是合法的八进制数:
256(无前缀0)03A2(包含了非八进制数码) -0127(出现了负号)
2.十六进制整常数
十六进制整常数的前缀为0X或0x。
其数码取值为0~9,A~F或a~f。
以下各数是合法的十六进制整常数:
0X2A(十进制为42) 0XA0(十进制为160) 0XFFFF(十进制为65535)
以下各数不是合法的十六进制整常数:
5A(无前缀0X) 0X3H(含有非十六进制数码)
3.十进制整常数
十进制整常数没有前缀。
其数码为0~9。
以下各数是合法的十进制整常数:
237-568655351627
以下各数不是合法的十进制整常数:
023(不能有前导0) 23D(含有非十进制数码)
在程序中是根据前缀来区分各种进制数的。
因此在书写常数时不要把前缀弄错造成结果不正确。
4.整型常数的后缀在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)
长整数158L和基本整常数158在数值上并无区别。
但对158L,因为是长整型量,C编译系统将为它分配4个字节存储空间。
而对158,因为是基本整型,只分配2个字节的存储空间。
因此在运算和输出格式上要予以注意,避免出错。
无符号数也可用后缀表示,整型常数的无符号数的后缀为“U”或“u”。
358u,0x38Au,235Lu均为无符号数。
前缀,后缀可同时使用以表示各种类型的数。
如0XA5Lu表示十六进制无符号长整数A5,其十进制为165。
整型变量
整型变量可分为以下几类:
1.基本型
类型说明符为int,在内存中占2个字节,其取值为基本整常数。
2.短整量
类型说明符为shortint或short'
C110F1。
所占字节和取值范围均与基本型相同。
3.长整型
类型说明符为longint或long,在内存中占4个字节,其取值为长整常数。
4.无符号型
类型说明符为unsigned。
无符号型又可与上述三种类型匹配而构成:
(1)无符号基本型类型说明符为unsignedint或unsigned。
(2)无符号短整型类型说明符为unsignedshort
(3)无符号长整型类型说明符为unsignedlong
各种无符号类型量所占的内存空间字节数与相应的有符号类型量相同。
但由于省去了符号位,故不能表示负数。
下表列出了TurboC中各类整型量所分配的内存字节数及数的表示范围。
类型说明符 数的范围 分配字节数
int -32768~32767 ■■
shortint -32768~32767 ■■
signedint -32768~32767 ■■
unsignedint 0~65535 ■■
longint -2147483648~2147483647 ■■■■
unsignedlong 0~4294967295 ■■■■
整型变量的说明
变量说明的一般形式为:
类型说明符变量名标识符,变量名标识符,...;
例如:
inta,b,c;
(a,b,c为整型变量)
longx,y;
(x,y为长整型变量)
unsignedp,q;
(p,q为无符号整型变量)
在书写变量说明时,应注意以下几点:
1.允许在一个类型说明符后,说明多个相同类型的变量。
各变量名之间用逗号间隔。
类型说明符与变量名之间至少用一个空格间隔。
2.最后一个变量名之后必须以“;
”号结尾。
3.变量说明必须放在变量使用之前。
一般放在函数体的开头部分。
[Practice]//1inta,b;
shortintc;
shortd=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,0
d,2,100
ofVtable
Vupdate
1,0;
2,0
3,0
4,100
1,80
2,180
3,360
4,200
ofVupdate
ofPractice
[Practice]//2inta=5;
intb=9;
longintc;
longd;
c=a+b-7;
d=a*b*c;
c=d*d*d;
a=c-d;
a,2,5
b,2,9
c,4,0
d,4,0
1,5
2,9
4,0
3,7
4,315
3,31255875
1,-5112
[Practice]//3inta=6,b=19;
unsignedintc;
intd;
c=a-b+7;
d=b*c;
a=b+c+d;
b=-a;
a,2,6
b,2,19
d,2,0
1,6;
2,19
3,65530
4,-114
1,-101
2,101
voidmain(){
inta,b,c,d;
x=5;
y=6;
a=7;
b=8;
c=x+a;
d=y+b;
printf("
c=x+a=%d,d=y+b=%d\n"
c,d);
}
将main说明为返回void,即不返回任何类型的值
x,y被定义为long型
a,b,c,d被定义为int型
5->
x
6->
y
7->
a
8->
b
x+a->
c
y+b->
d
显示程序运行结果oflongx,y;
从程序中可以看到:
x,y是长整型变量,a,b是基本整型变量。
它们之间允许进行运算,运算结果为长整型。
但c,d被定义为基本整型,因此最后结果为基本整型。
本例说明,不同类型的量可以参与运算并相互赋值。
其中的类型转换是由编译系统自动完成的。
有关类型转换的规则将在以后介绍。
实型量
实型常量
实型也称为浮点型。
实型常量也称为实数或者浮点数。
在C语言中,实数只采用十进制。
它有二种形式:
十进制数形式指数形式
1.十进制数形式
由数码0~9和小数点组成。
0.0,.25,5.789,0.13,5.0,300.,-267.8230等均为合法的实数。
2.指数形式
由十进制数,加阶码标志“e”或“E”以及阶码(只能为整数,可以带符号)组成。
其一般形式为aEn(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(无阶码)
标准C允许浮点数使用后缀。
后缀为“f”或“F”即表示该数为浮点数。
如356f和356.是等价的。
例2.2说明了这种情况:
voidmain()
{
%f\n%f\n"
356.,356f);
void指明main不返回任何值 利用printf显示结果 结束
实型变量
实型变量分为两类:
单精度型和双精度型,
其类型说明符为float单精度说明符,double双精度说明符。
在TurboC中单精度型占4个字节(32位)内存空间,其数值范围为3.4E-38~3.4E+38,只能提供七位有效数字。
双精度型占8个字节(64位)内存空间,其数值范围为1.7E-308~1.7E+308,可提供16位有效数字。
实型变量说明的格式和书写规则与整型相同。
floatx,y;
(x,y为单精度实型量)
doublea,b,c;
(a,b,c为双精度实型量)
实型常数不分单、双精度,都按双精度double型处理。
floata;
doubleb;
a=33333.33333;
b=33333.33333333333333;
a,b);
此程序说明float、double的不同
a■