c程序设计谭浩强第03章课件.ppt
《c程序设计谭浩强第03章课件.ppt》由会员分享,可在线阅读,更多相关《c程序设计谭浩强第03章课件.ppt(110页珍藏版)》请在三一办公上搜索。
1、第3章 数据类型、运算符与表达式,3.1 C的数据类型3.2 常量与变量3.3 整型数据3.4 实型数据3.5 字符型数据3.6 变量赋初值,3.7 各类数值型数据间的混合运算3.8 算术运算符和算术表达式3.9 赋值运算符和赋值表达式3.10 逗号运算符和逗号表达式,3.1 C的数据类型,数据结构+算法=程序其中,(1)对操作的描述。即操作步骤,也就是算法(algorithm)。(2)对数据的描述。在程序中要指定数据的类型和数据的组织形式,即数据结构(data structure)。处理同一类问题,如果数据结构不同,算法也会不同。因此,在考虑算法时,必须注意数据结构。,C语言的数据结构是以数
2、据类型形式出现的。C的数据类型如下:,由以上这些数据类型还可以构成更复杂的数据结构。例如利用指针和结构体类型可以构成表、树、栈等复杂的数据结构。,3.2 常量与变量,3.2.1 常量和符号常量常量:在程序运行过程中,其值不能被改变的量。常量区分为不同的类型,如12,0,-3为整型常量,4.6、-1.23为实型常量,a,d为字符常量。常量一般从其字面形式即可判别,这种常量称为字面常量或直接常量。,用一个标识符代表一个常量,称为符号常量。例3.1符号常量的使用。#define PRICE 30#include main()int num,total;num=10;total=num*PRICE;p
3、rintf(total=%d,total);本文件中出现的PRICE都代表30,可以像常量一样进行运算.,请注意符号常量不同于变量,它的值在其作用域(在本例中为主函数)内不能改变,也不能再被赋值。如再用以下赋值语句给PRICE赋值是错误的。PRICE=40;习惯上,符号常量名用大写,变量用小写,以示区别。使用符号常量的好处是:(1)含义清楚。如上面的程序中,看程序时从PRICE就可知道它代表价格。因此定义符号常量名时应考虑“见名知意”。(2)在需要改变一个常量时能做到“一改全改”。,3.2.2 变量变量:其值在程序运行期间可以改变的量。一个变量应该有一个名字,在内存中占据一定的存储单元。在该存
4、储单元中存放变量的值。请注意区分变量名和变量值这两个不同的概念,见图3.1。变量名实际上是一个符号地址,在对程序编译连接时由系统给每一个变量名分配一个内存地址。在程序中从变量中取值,实际上是通过变量名找到相应的内存地址,从其存储单元中读取数据。,图3.1,用来标识变量名、符号常量名、函数名、数组名、类型名、文件名的有效字符序列称为标识符(identifier)。C语言规定标识符只能由字母、数字和下划线三种字符组成,且第一个字符必须为字母或下划线。下面列出的哪些是合法的标识符,哪些不是合法的变量名:sum,average,_total,day,student_name,lotus_1_2_3,(
5、li-ling,M.d.John,33,3d64,ab是错误的),注意,大写字母和小写字母被认为是两个不同的字符,即“大小写敏感”。因此,sum和SUM是两个不同的变量名。ANSI C标准没有规定标识符的长度,但各个c编译系统都有自己的规定。有的系统取8个字符,假如程序中出现的变量名长度大于8个字符,则只有前面8个字符有效,后面的不被识别。例如,有两个变量:student_name和student_number,由于二者的前8个字符相同,系统认为这两个变量是一回事而不加区别。可以将它们改为stud_name和stud_num,以使之区别。,为了程序的可移植性(即在甲机器上运行的程序可以基本上不
6、加修改,就能移到乙机器上运行)以及阅读程序的方便,建议变量名的长度不要超过8个字符。在选择变量名和其他标识符时,应注意做到“见名知意”,如count、name、day、month、total、country等;,共性规则,标识符最好采用英文单词 或其组合,便于记忆和阅读。切忌使用汉语拼音来命名。程序中的英文单词用词应当准确。例如不要把CurrentValue写成NowValue。几十年前老ANSI C规定名字不准超过6个字符,现今的C+/C不再有此限制。一般来说,长名字能更好地表达含义,所以函数名、变量名、类名长达十几个字符不足为怪。那么名字是否越长越好?不见得!单字符的名字也是有用的,常见的
7、如i,j,k,m,n,x,y,z等,它们通常可用作函数内的局部变量。,命名规则尽量与所采用的操作系统或开发工具的风格保持一致。例如Windows应用程序的标识符(主要是函数名)通常采用“大小写”混排的方式,如AddChild。而Unix应用程序的标识符通常采用“小写加下划线”的方式,如add_child。别把这两类风格混在一起用。程序中不要出现仅靠大小写区分的相似的标识符。例如:int x,X;/变量x 与 X 容易混淆void foo(int x);/函数foo 与FOO容易混淆void FOO(float x);,在c语言中,所有变量“先定义,后使用”,因为:(1)凡未被事先定义的,不作为
8、变量名,这就能保证程序中变量名使用得正确。例如,如果在定义部分写了int student;而在执行语句中错写成stadent。如:stadent=30;在编译时检查出statent未经定义,不作为变量名。因此输出“变量statent未经声明”的信息。,(2)每一个变量被指定为一确定类型,在编译时就能为其分配相应的存储单元。如指定a、b为int型,turbo c编译系统为a和b各分配两个字节,并按整数方式存储数据。(3)指定每一变量属于一个类型,这就便于在编译时,据此检查该变量所进行的运算是否合法。例如,整型变量a和b,可以进行求余运算:a%b 但如果将a、b指定为实型变量,则不允许进行“求余”
9、运算,在编译时会给出有关“出错信息”。,3.3 整型数据,3.3.1 整型常量的表示方法整型常量即整常数。C整常数可用以下三种形式表示:(1)十进制整数。如123,-456,0。(2)八进制整数。以0开头的数是八进制数。如0123表示八进制数123,即(123)8。-011表示八进制数-11,即十进制数-9。(3)十六进制整数。以0 x开头的数是十六进制数。如0 x123,代表十六进制数123。-0 x12等于十进制数-18。,3.3.2 整型变量,1.整型数据在内存中是以二进制形式存放的。如:int i;/*定义为整型变量*/i=10;/*给i赋以整数10*/十进制数10的二进制形式为101
10、0TC系统为每一个整型变量在内存中分配2个字节,而VC6.0分配4个字节。,图3.2(a)是数据存放的示意图。图3.2(b)是数据在内存中实际存放的情况。实际上,数值是以补码(complement)表示的。一个正数的补码和其原码的形式相同。如图3.2(b)。求负数的补码的方法是:将该数的绝对值的二进制形式,按位取反再加1。例如求-10的补码:取-10的绝对值10;10的绝对值的二进制形式为1010;,图3.3可知整数的16位中,最左面的一位是符号位,该位为0,表示数值为正;为1则数值为负。,2.整型变量的分类,整型变量的基本类型符为int。根据数值的范围在int 之前可以根据需要分别加上修饰符
11、:short(短型)或long(长型)。从而分为以下三种整型变量:(1)基本整型,以int表示。(2)短整型,以short int表示,或以short表示。(3)长整型,以long int表示,或以long表示。,在turbo c中一个int型的变量的值范围为-215(215-1),即-3276832767。在实际应用中,变量的值常常是正的(如学号、库存量、年龄、存款额等)。为了充分利用变量的表数范围,此时可以将变量定义为“无符号”类型。对以上三种都可以加上修饰符unsigned,以指定是“无符号数”。如果加上修饰符signed,则指定是“有符号数”。如果既不指定为signed,也不指定为un
12、signed,则隐含为有符号(signed)。实际上signed一般不写。,归纳起来,可以用以下6种整型变量。即:有符号基本整型 signed int 无符号基本整型 unsigned int有符号短整型 signed short int无符号短整型 unsigned short int有符号长整型 signed long int无符号长整型 unsigned long int方括弧内的部分是可以省略的.如果指定unsigned,为无符号型,存储单元中全部二进位(bit)用作存放数本身,而不包括符号。无符号型变量只能存放不带符号的整数,如123、4687等,而不能存放负数,如-123、-3。,
13、一个无符号整型变量中可以存放的正数的范围比一般整型变量中正数的范围扩大一倍。如果在程序中定义a和b两个变量:int a;unsigned int b;则变量a的数值范围为-3276832767。而变量b的数值范围为065535。,表示有符号整型变量a的最大值(32767)。(b)表示无符号整型变量b的最大值(65535)。,C标准没有具体规定以上各类数据所占内存字节数,只要求long型数据长度不短于int型,short型不长于int型。具体如何实现,由各计算机系统的字长决定:long在16和32位操作系统中都是32位。short在16和32位操作系统中都是16位。16位操作系统(DOS,Win
14、dows 3.x)int是16位的.32位操作系统(Windows 9x/NT/2000/XP)int是32位的(范围达21亿).,一个整数(以13为例)在存储单元中的存储情况,见图3.5所示。,图3.5,/求某数据类型能表示的最大数#include void main()int i;double max=1;for(i=sizeof(int)*8;i0;i-)max*=2;max-;printf(%fn,max);,3.整型变量的定义,前面已提到,c规定在程序中所有用到的变量都必须在程序中“先定义,后使用”,即“强制类型定义”。例如:int a,b;(指定变量a、b为整型)unsigned
15、short c,d;(指定变量c、d为无符号短整型)long e,f;(指定变量e、f为长整型)对变量的定义,一般是放在一个函数的开头部分的声明部分。,例3.2整型变量的定义与使用。,void main()int a,b,c,d;/定义a、b、c、d为整型变量 unsigned u;/定义u为无符号整型变量 a=12;b=-24;u=10;c=a+u;d=b+u;printf(a+u=%d,b+u=%dn,c,d);运行结果为:a+u=22,b+u=-14可以看到不同种类的整型数据可以进行算术运算。,4.整型数据的溢出,假如,在VC中一个int型变量的最大允许值为2147483647(0 x7
16、fffffff),如果再加1,会出现什么情况?例3.3整型数据的溢出。void main()int a=2147483647,b;b=a+1;printf(%d,%dn,a,b);运行结果为:2147483647,-2147483648,请注意:遇此情况就发生“溢出”,但运行时并不报错。将变量b改成范围更大的数据类型。,图3.6,3.3.3 整型常量的类型,我们已知整型变量可分为int、short int、long int和unsigned int、unsigned short、unsigned long等类别。那么常量是否也有这些类别?在将一个整型常量赋值给上述几种类别的整型变量时如何做到类
17、型匹配?请注意以下几点:(1)一个整数,如果其值在-2147483648+2147483647范围内,认为它是int型,它可以赋值给int型和long int型变量。,(2)一个int型的常量也同时是一个long int型常量,可以赋给int型或long int型变量。(3)一个整常量后面加一个字母u,认为是unsigned int型,如12345u,在内存中按unsigned int规定的方式存放(存储单元中最高位不作为符号位,而用来存储数据。(4)在一个整常量后面加一个字母l或L,则认为是long int型常量。例如123l、432L、0L等,这往往用于函数调用中。如果函数的形参为long
18、 int型,则要求实参也为long int型。,3.4 实型数据,3.4.1 实型常量的表示方法实数(real number)又称浮点数(floating-point number)。实数有两种表示形式:(1)十进制小数形式。它由数字和小数点组成(注意必须有小数点)。0.123、123.、123.0、0.0都是十进制小数形式。(2)指数形式。如123e3或123E3都代表123103。但注意字母e(或E)之前必须有数字,且e后面的指数必须为整数,如e3、2.1e3.5、e3、e等都不是合法的指数形式。,1.实型数据在内存中的存放形式 在常用的微机系统中,一个实型数据在内存中占4个字节(32位)
19、。与整型数据的图3.7存储方式不同,实型数据是按照指数形式存储的。系统把一个实型数据分成小数部分和指数部分,分别存放。指数部分采用规范化的指数形式。实数 3.14159 在内存中的存放形式可以用图3.7示意。,实型变量,图3.7,图中是用十进制数来示意的,实际上在计算机中是用二进制数来表示小数部分以及用2的幂次来表示指数部分的。在4个字节(32位)中,究竟用多少位来表示小数部分,多少位来表示指数部分,标准C并无具体规定,由各C编译系统自定。小数部分占的位(bit)数愈多,数的有效数字愈多,精度愈高。指数部分占的位数愈多,则能表示的数值范围愈大。,2.实型变量的分类,C实型变量分为单精度(flo
20、at型)、双精度(double型)和长双精度型(long double)三类。ANSI C 并未具体规定每种类型数据的长度、精度和数值范围。有的系统将double型(8字节)所增加的32位全用于存放小数部分,这样可以增加数值的有效位数,减少舍入误差。有的系统则将所增加的位(bit)用于存放指数部分,这样可以扩大数值的范围。表3.2列出的是微机上常用的c编译系统(如turbo c,Ms c,borland c)的情况。应当了解,不同的系统会有差异。,对每一个实型变量都应在使用前加以定义。如:float x,y,(指定x、y为单精度实数)double z;(指定z为双精度实数)long doubl
21、e t;(指定t为长双精度实数,少用),3.实型数据的舍入误差,由于实型变量是由有限的存储单元组成的,因此能提供的有效数字总是有限的,在有效位以外的数字将被舍去。由此可能会产生一些误差。例如,(a20)应该比a大?例3.4 实型数据的舍入误差。,void main()float a,b;a=123456.789e5;b=a+20;printf(%f,b);“%f”是输出一个实数时的格式符。一个实型变量只能保证的有效数字是7位有效数字,后面的数字是无意义的,并不准确地表示该数。,应当避免将一个很大的数和一个很小的数直接相加或相减,否则就会“丢失”小的数。与此类似,用程序计算1.0/3*3的结果可
22、能不等于1。,3.4.3 实型常量的类型,C编译系统将实型常量作为双精度来处理。例如已定义一个实型变量f,有如下语句:f=2.45678*4523.65 这样做可以保证计算结果更精确,但是运算速度降低了。可以在数的后面加字母f或F(如1.65f,654.87F),这样编译系统就会按单精度(32位)处理。,一个实型常量可以赋给一个float型、double型或long double变量。赋值时根据变量的类型截取实型常量中相应的有效位数字。假如a已指定为单精度实型变量:float a;a=111111.111;由于float型变量只能接收7位有效数字,因此最后两位小数可能不起作用。如果a改为dou
23、ble型,则能全部接收上述9位数字并存储在变量a中。,3.5 字符型数据,3.5.1 字符常量C的字符常量是用单引号(即撇号)括起来的一个字符。如a,x,d,?,等都是字符常量。注意,a和A是不同的字符常量。除了以上形式的字符常量外,C还允许用一种特殊形式的字符常量,就是以一个“”开头的转义字符。例如,n,它代表一个“换行”符。这是一种“控制字符”,在屏幕上是不能显示的。常用转义字符,见P48 表33,例3.5转义字符的使用。void main()printf(“ab ct derftgn);printf(htibbj k);其中,“t”的作用是“跳格”,即跳到下一个“制表位置”,一个“制表区
24、”占8列,“下一个制表位置”从第9列开始。“r”,它代表“回车”(不换行)“n”,作用是“使当前位置移到下一行的开头”“b”,作用是“退一格”,程序运行时在打印机上得到以下结果:fab c gde h jik注意在显示屏上的结果:f gde h j k结果不同的原因:“r”使当前位置回到本行开头,自此输出的字符(包括空格和跳格所经过的位置)将取代原来屏幕上该位置上显示的字符。而在打印机输出时,不像显示屏那样会“抹掉”原字符,留下了不可磨灭的痕迹,它能真正反映输出的过程和结果。,3.5.2 字符变量,字符型变量用来存放字符常量,请注意只能放一个字符。字符变量的定义形式如下:charc1,c2;c
25、1=a;c2=b;在所有的编译系统中都规定以一个字节来存放一个字符,或者说一个字符变量在内存中占一个字节。,3.5.3 字符数据在内存中的存储形式及其使用方法,将一个字符常量放到一个字符变量中,实际上并不是把该字符本身放到内存单元中去,而是将该字符的相应的ASCII代码放到存储单元中。例如字符a的ASCII代码为97,b为98,在内存中变量c1、c2的值如图3.8(a)所示。实际上是以二进制形式存放的,如图3.8(b)所示。,图3.8,既然在内存中,字符数据以ASCII码存储,它的存储形式就与整数的存储形式类似。这样,字符型数据和整型数据之间就可以互相转换。一个字符数据既可以以字符形式(%c)
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 程序设计 谭浩强第 03 课件
链接地址:https://www.31ppt.com/p-6503661.html