资源预览内容
第1页 / 共30页
第2页 / 共30页
第3页 / 共30页
第4页 / 共30页
第5页 / 共30页
第6页 / 共30页
第7页 / 共30页
第8页 / 共30页
第9页 / 共30页
第10页 / 共30页
亲,该文档总共30页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述
C C 语言教程第二章语言教程第二章 数据类型、运算符、表达式数据类型、运算符、表达式C 语言教程第二章 数据类型、运算符、表达式语言的数据类型在第一课中,我们已经看到程序中使用的各种变量都应预先加以说明,即先说明,后使用。对变量的说明可以包括三个方面:数据类型存储类型作用域在本课中,我们只介绍数据类型说明。其它说明在以后各章中陆续介绍。所谓数据类型是按被说明量的性质,表示形式,占据存储空间的多少,构造特点来划分的。在语言中,数据类型可分为:基本数据类型,构造数据类型,指针类型,空类型四大类。1.基本数据类型基本数据类型最主要的特点是,其值不可以再分解为其它类型。也就是说,基本数据类型是自我说明的。2.构造数据类型构造数据类型是根据已定义的一个或多个数据类型用构造的方法来定义的。也就是说,一个构造类型的值可以分解成若干个“成员”或“元素” 。每个“成员”都是一个基本数据类型或又是一个构造类型。在 C 语言中,构造类型有以下几种: 数组类型结构类型联合类型3.指针类型指针是一种特殊的,同时又是具有重要作用的数据类型。其值用来表示某个量在内存储器中的地址。虽然指针变量的取值类似于整型量,但这是两个类型完全不同的量,因此不能混为一谈。4.空类型在调用函数值时,通常应向调用者返回一个函数值。这个返回的函数值是具有一定的数据类型的,应在函数定义及函数说明中给以说明,例如在例题中给出的 max 函数定义中,函数头为: int max(int a,int b);其中“int ”类型说明符即表示该函数的返回值为整型量。又如在例题中,使用了库函数 sin,由于系统规定其函数返回值为双精度浮点型,因此在赋值语句 s=sin (x);中,s 也必须是双精度浮点型,以便与 sin 函数的返回值一致。所以在说明部分,把 s 说明为双精度浮点型。但是,也有一类函数,调用后并不需要向调用者返回函数值, 这种函数可以定义为“空类型” 。其类型说明符为 void。在第五章函数中还要详细介绍。在本章中,我们先介绍基本数据类型中的整型、浮点型和字符型。其余类型在以后各章中陆续介绍。对于基本数据类型量,按其取值是否可改变又分为常量和变量两种。在程序执行过程中,其值不发生改变的量称为常量,取值可变的量称为变量。它们可与数据类型结合起来分类。例如,可分为整型常量、整型变量、浮点常量、浮点变量、字符常量、字符变量、枚举常量、枚举变量。在程序中,常量是可以不经说明而直接引用的,而变量则必须先说明后使用。整型量整型量包括整型常量、整型变量。整型常量就是整常数。在语言中,使用的整常数有八进制、十六进制和十进制三种。整型常量1.八进制整常数八进制整常数必须以 0 开头,即以 0 作为八进制数的前缀。数码取值为 07。八进制数通常是无符号数。以下各数是合法的八进制数: 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。以下各数是合法的十进制整常数:237 -568 65535 1627以下各数不是合法的十进制整常数:023 (不能有前导 0) 23D (含有非十进制数码在程序中是根据前缀来区分各种进制数的。因此在书写常数时不要把前缀弄错造成结果不正确。4.整型常数的后缀在 16 位字长的机器上,基本整型的长度也为 16 位,因此表示的数的范围也是有限定的。十进制无符号整常数的范围为 065535,有符号数为-32768+32767。八进制无符号数的表示范围为 00177777。十六进制无符号数的表示范围为 0X00XFFFF 或 0x00xFFFF。如果使用的数超过了上述范围,就必须用长整型数来表示。长整型数是用后缀“L”或“l”来表示的。例如:十进制长整常数 158L (十进制为 158) 358000L (十进制为-358000)八进制长整常数 012L (十进制为 10) 077L (十进制为 63) 0200000L (十进制为 65536)十六进制长整常数 0X15L (十进制为 21) 0XA5L (十进制为 165) 0X10000L (十进制为 65536)长整数 158L 和基本整常数 158 在数值上并无区别。但对158L,因为是长整型量,编译系统将为它分配 4 个字节存储空间。而对 158,因为是基本整型,只分配 2 个字节的存储空间。因此在运算和输出格式上要予以注意,避免出错。无符号数也可用后缀表示,整型常数的无符号数的后缀为“U”或“u” 。例如: 358u,0x38Au,235Lu 均为无符号数。前缀,后缀可同时使用以表示各种类型的数。如 0XA5Lu 表示十六进制无符号长整数 A5,其十进制为 165。整型变量整型变量可分为以下几类:1.基本型类型说明符为 int,在内存中占 2 个字节,其取值为基本整常数。2.短整量类型说明符为 short int 或 shortC110F1。所占字节和取值范围均与基本型相同。3.长整型类型说明符为 long int 或 long ,在内存中占 4 个字节,其取值为长整常数。4.无符号型类型说明符为 unsigned。无符号型又可与上述三种类型匹配而构成:(1)无符号基本型 类型说明符为 unsigned int 或 unsigned。(2)无符号短整型 类型说明符为 unsigned short(3)无符号长整型 类型说明符为 unsigned long 各种无符号类型量所占的内存空间字节数与相应的有符号类型量相同。但由于省去了符号位,故不能表示负数。 下表列出了 Turbo C中各类整型量所分配的内存字节数及数的表示范围。类型说明符 数的范围 分配字节数int -3276832767 short int -3276832767 signed int -3276832767 unsigned int 065535 long int -21474836482147483647 unsigned long 04294967295 整型变量的说明变量说明的一般形式为: 类型说明符 变量名标识符,变量名标识符,.; 例如: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;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=abc;c=ddd;a=c-d;Vtablea,2,5b,2,9c,4,0d,4,0of VtableVupdate1,52,93,04,03,74,3153,312558751,-5112of Vupdateof PracticePractice 3int a=6,b=19;unsigned int c;int d;c=a-b+7;d=bc;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,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.0,.25,5.789,0.13,5.0,300.,-267.8230 等均为合法的实数。2.指数形式由十进制数,加阶码标志“e”或“E”以及阶码(只能为整数,可以带符号)组成。其一般形式为 a E n (a 为十进制数,n 为十进制整数)其值为 a10,n 如: 2.1E5 (等于 2.110,5), 3.7E-2 (等于 3.710,)-2) 0.5E7 (等于 0.510,7), -2.8E-2 (等于-2.810,)-2)以下不是合法的实数 345 (无小数点) E7 (阶码标志 E 之前无数字) -5 (无阶码标志) 53.-E3 (负号位置不对) 2.7E (无阶码)标准允许浮点数使用后缀。后缀为“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 a-33333.33333b-33333.33333333333;显示程序结果此程序说明 float、double 的不同float a;double b;a=33333.33333;b=
网站客服QQ:2055934822
金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号