c语言运算符及其表达式

上传人:大米 文档编号:508450750 上传时间:2023-02-16 格式:DOC 页数:19 大小:34.96KB
返回 下载 相关 举报
c语言运算符及其表达式_第1页
第1页 / 共19页
c语言运算符及其表达式_第2页
第2页 / 共19页
c语言运算符及其表达式_第3页
第3页 / 共19页
c语言运算符及其表达式_第4页
第4页 / 共19页
c语言运算符及其表达式_第5页
第5页 / 共19页
点击查看更多>>
资源描述

《c语言运算符及其表达式》由会员分享,可在线阅读,更多相关《c语言运算符及其表达式(19页珍藏版)》请在金锄头文库上搜索。

1、C语言的数据类型运算符表达式1.基本数据类型基本数据类型最主要的特点是,其值不可以再分解为其它类型。也就是说,基本数据类型是自我说明的。2.构造数据类型构造数据类型是根据已定义的一个或多个数据类型用构造的方法来定义的。也就是说,一个构造类型的值可以分解成若干个“成员”或“元素”。每个“成员”都是一个基本数据类型或又是一个构造类型。在C语言中,构造类型有以下几种: 数组类型结构类型联合类型3.指针类型指针是一种特殊的,同时又是具有重要作用的数据类型。其值用来表示某个量在内存储器中的地址。虽然指针变量的取值类似于整型量,但这是两个类型完全不同的量,因此不能混为一谈。4.空类型在调用函数值时,通常应

2、向调用者返回一个函数值。这个返回的函数值是具有一定的数据类型的,应在函数定义及函数说明中给以说明,例如在例题中给出的max函数定义中,函数头为: int max(int a,int b);其中“int ”类型说明符即表示该函数的返回值为整型量。又如在例题中,使用了库函数 sin,由于系统规定其函数返回值为双精度浮点型,因此在赋值语句s=sin (x);中,s 也必须是双精度浮点型,以便与sin函数的返回值一致。所以在说明部分,把s说明为双精度浮点型。但是,也有一类函数,调用后并不需要向调用者返回函数值, 这种函数可以定义为“空类型”。其类型说明符为void。在第五章函数中还要详细介绍。在本章中

3、,我们先介绍基本数据类型中的整型、浮点型和字符型。其余类型在以后各章中陆续介绍。对于基本数据类型量,按其取值是否可改变又分为常量和变量两种。在程序执行过程中,其值不发生改变的量称为常量,取值可变的量称为变量。它们可与数据类型结合起来分类。例如,可分为整型常量、整型变量、浮点常量、浮点变量、字符常量、字符变量、枚举常量、枚举变量。在程序中,常量是可以不经说明而直接引用的,而变量则必须先说明后使用。整型量整型量包括整型常量、整型变量。整型常量就是整常数。在语言中,使用的整常数有八进制、十六进制和十进制三种。整型常量1.八进制整常数八进制整常数必须以0开头,即以0作为八进制数的前缀。数码取值为07。

4、八进制数通常是无符号数。以下各数是合法的八进制数: 015(十进制为13)0101(十进制为65)0177777(十进制为65535)以下各数不是合法的八进制数: 256(无前缀0) 03A2(包含了非八进制数码)-0127(出现了负号)2.十六进制整常数十六进制整常数的前缀为0X或0x。其数码取值为09,AF或af。以下各数是合法的十六进制整常数:0X2A(十进制为42)0XA0 (十进制为160)0XFFFF (十进制为65535)以下各数不是合法的十六进制整常数: 5A (无前缀0X)0X3H (含有非十六进制数码)3.十进制整常数十进制整常数没有前缀。其数码为09。以下各数是合法的十进

5、制整常数:237 -568 65535 1627以下各数不是合法的十进制整常数:023 (不能有前导0)23D (含有非十进制数码)在程序中是根据前缀来区分各种进制数的。因此在书写常数时不要把前缀弄错造成结果不正确。4.整型常数的后缀在16位字长的机器上,基本整型的长度也为16位,因此表示的数的范围也是有限定的。十进制无符号整常数的范围为065535,有符号数为-32768+32767。八进制无符号数的表示范围为00177777。十六进制无符号数的表示范围为0X00XFFFF或0x00xFFFF。如果使用的数超过了上述范围,就必须用长整型数来表示。长整型数是用后缀“L”或“l”来表示的。例如:

6、十进制长整常数 158L (十进制为158) 358000L (十进制为-358000)八进制长整常数 012L (十进制为10) 077L (十进制为63)0200000L (十进制为65536)十六进制长整常数 0X15L (十进制为21) 0XA5L (十进制为165)0X10000L (十进制为65536)长整数158L和基本整常数158 在数值上并无区别。但对158L,因为是长整型量,编译系统将为它分配4个字节存储空间。而对158,因为是基本整型,只分配2 个字节的存储空间。因此在运算和输出格式上要予以注意,避免出错。无符号数也可用后缀表示,整型常数的无符号数的后缀为“U”或“u”。

7、例如: 358u,0x38Au,235Lu 均为无符号数。前缀,后缀可同时使用以表示各种类型的数。如0XA5Lu表示十六进制无符号长整数A5,其十进制为165。整型变量整型变量可分为以下几类:1.基本型类型说明符为int,在内存中占2个字节,其取值为基本整常数。2.短整量类型说明符为short int或shortC110F1。所占字节和取值范围均与基本型相同。3.长整型类型说明符为long int或long ,在内存中占4个字节,其取值为长整常数。4.无符号型类型说明符为unsigned。无符号型又可与上述三种类型匹配而构成:(1)无符号基本型 类型说明符为unsigned int或unsig

8、ned。(2)无符号短整型 类型说明符为unsigned short(3)无符号长整型 类型说明符为unsigned long 各种无符号类型量所占的内存空间字节数与相应的有符号类型量相同。但由于省去了符号位,故不能表示负数。 下表列出了Turbo C中各类整型量所分配的内存字节数及数的表示范围。类型说明符数的范围 分配字节数int -3276832767 short int -3276832767 signed int -3276832767 unsigned int 065535 long int -21474836482147483647unsigned long 04294967295

9、 整型变量的说明变量说明的一般形式为: 类型说明符 变量名标识符,变量名标识符,.; 例如:int a,b,c; (a,b,c为整型变量)long x,y; (x,y为长整型变量)unsigned p,q; (p,q为无符号整型变量)在书写变量说明时,应注意以下几点:1.允许在一个类型说明符后,说明多个相同类型的变量。各变量名之间用逗号间隔。类型说明符与变量名之间至少用一个空格间隔。2.最后一个变量名之后必须以“;”号结尾。3.变量说明必须放在变量使用之前。一般放在函数体的开头部分。Practice /1int a,b;short int c;short d=100;a=d-20;b=a+d;

10、c=a+b+d;d=d-a+c-b;Vtablea,2,0b,2,0c,2,0d,2,100of VtableVupdate1,0;2,03,04,1001,802,1803,3604,200of Vupdateof PracticePractice /2int a=5;int b=9;long int c;long d;c=a+b-7;d=a*b*c;c=d*d*d;a=c-d;Vtablea,2,5b,2,9c,4,0d,4,0of VtableVupdate1,52,93,04,03,74,3153,312558751,-5112of Vupdateof PracticePractice

11、 /3int a=6,b=19;unsigned int c;int d;c=a-b+7;d=b*c;a=b+c+d;b=-a;Vtablea,2,6b,2,19c,2,0d,2,0of VtableVupdate1,6;2,193,04,03,655304,-1141,-1012,101of Vupdateof Practicevoid main()long x,y;int a,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=%dn,c,d);将main说明为返回void,即不返回任何类型的值x,y被定义为long型a,b,c,

12、d被定义为int型5-x6-y7-a8-bx+a-cy+b-d显示程序运行结果 of long x,y;int a,b,c,d;c=x+a;d=y+b;从程序中可以看到:x, y是长整型变量,a, b是基本整型变量。它们之间允许进行运算,运算结果为长整型。但c,d被定义为基本整型,因此最后结果为基本整型。本例说明,不同类型的量可以参与运算并相互赋值。其中的类型转换是由编译系统自动完成的。有关类型转换的规则将在以后介绍。实型量实型常量实型也称为浮点型。实型常量也称为实数或者浮点数。在语言中,实数只采用十进制。它有二种形式: 十进制数形式指数形式1.十进制数形式由数码0 9和小数点组成。例如:0.

13、0,.25,5.789,0.13,5.0,300.,-267.8230等均为合法的实数。2.指数形式由十进制数,加阶码标志“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 (无阶码)标准允许浮点数使用后缀。后缀

14、为“f”或“F”即表示该数为浮点数。如356f和356.是等价的。例2.2说明了这种情况:void main()printf(%fn%fn,356.,356f);void 指明main不返回任何值利用printf显示结果结束实型变量实型变量分为两类:单精度型和双精度型,其类型说明符为float 单精度说明符,double 双精度说明符。在Turbo C中单精度型占4个字节(32位)内存空间,其数值范围为3.4E-383.4E+38,只能提供七位有效数字。双精度型占8 个字节(64位)内存空间,其数值范围为1.7E-3081.7E+308,可提供16位有效数字。实型变量说明的格式和书写规则与整型相同。例如: float x,y; (x,y为单精度实型量) double a,b,c; (a,b,c为双精度实型量)实型常数不分单、双精度,都按双精度double型处理。void main()float a;double b;a=33333.33333;b=33333.33333333333333;printf(%fn%fn,a,b);此程序说明float、double的不同a b

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 幼儿/小学教育 > 小学课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号