第3章数据类型精选PPT.ppt
第第3 3章数据类型章数据类型第1页,本讲稿共49页基本类型基本类型构造类型构造类型指针类型指针类型空类型空类型整型整型浮点型(实型)浮点型(实型)字符型字符型枚举类型枚举类型短整型短整型长整型长整型短整型短整型数据类型数据类型无符号整型无符号整型单精度实型单精度实型双精度实型双精度实型数组类型数组类型结构体类型结构体类型联合类型联合类型数据类型(数据类型(Data TypeData Type)第2页,本讲稿共49页可以在C程序中用作标识符的一组是_n1)if,define,BYEDn2)bb_b3,_1234,Ifn3)FFF,FOR,-bcdn4)3d,DM,SSII第3页,本讲稿共49页n由英文字母、数字和下划线组成,大小写敏感由英文字母、数字和下划线组成,大小写敏感n不能有非法字符不能有非法字符n不可以不可以是数字开头是数字开头n不允许使用关键字作为标识符的名字不允许使用关键字作为标识符的名字 int,float,for,while,if等等标识符命名标识符命名第4页,本讲稿共49页n下面不是C语言整型常量的是。n1)012)0 x11n3)08 4)-32768第5页,本讲稿共49页u以数字以数字“0”开始的整型常数是八进制数开始的整型常数是八进制数0 02222、-0 037370 01010和和1010大小不一样大小不一样因为八进制并不常用,所以此种表示法比较少见因为八进制并不常用,所以此种表示法比较少见u以以“0 x0 x”或者或者“0X0X”开始的整型常数是十六进开始的整型常数是十六进制制A-FA-F和和a-fa-f用来表示十进制的用来表示十进制的10-1510-15十六进制的形式比较常用,尤其在进行位一级的控制的时候十六进制的形式比较常用,尤其在进行位一级的控制的时候0 x0 x1212、-0 x0 x1F,-1F,-0 x0 x1f1f八进制与十六进制常数八进制与十六进制常数第6页,本讲稿共49页 3.6 3.6变量赋初值变量赋初值 (2)可以使被定义的变量的一部分赋初值。如如:int a,b,c=5;表示指定、为整型变量,但只对初始化,c的初值为(3)如果对几个变量赋以同一个初值,应写成:int a=3,b=3,c=3;表示、的初值都是。不能写成 int a=b=c=3;注意:注意:初始化不是在编译阶段完成的而是在程序运行时执行本函数时赋初值的,相当于有一个赋值语句。第7页,本讲稿共49页3.73.7各类数值型数据间的混合运算各类数值型数据间的混合运算 整型(包括int,short,long)、浮点型(包括float,double)可以混合运算。在进行运算时,不同类型的数据要先转换成同一类型,然后进行运算.类型转换由系统自动进行横向:必定的转换纵向:不同类型时的转换方向第8页,本讲稿共49页 3.8 3.8算术运算符和算术表达式算术运算符和算术表达式3.8.1 运算符简介运算符简介 的运算符有以下几类:的运算符有以下几类:(1)算术运算符(+-*/%)(2)关系运算符(=!=)(3)逻辑运算符(!|)(4)位运算符 (|)(5)赋值运算符(及其扩展赋值运算符)(6)条件运算符(?:)(7)逗号运算符 (,)第9页,本讲稿共49页 3.8 3.8算术运算符和算术表达式算术运算符和算术表达式(8)指针运算符(*和)(9)求字节数运算符()(10)强制类型转换运算符((类型))(11)分量运算符(-)(12)下标运算符()(13)其他(如函数调用运算符()第10页,本讲稿共49页 3.8 3.8算术运算符和算术表达式算术运算符和算术表达式3.8.2 算术运算符和算术表达式算术运算符和算术表达式(1)(1)基本的算术运算符基本的算术运算符:(加法运算符,或正值运算符。如:、)(减法运算符,或负值运算符。如:、)*(乘法运算符。如:*)(除法运算符。如:)(模运算符,或称求余运算符,两侧均应为整型数据,如:的值为)。第11页,本讲稿共49页 3.8 3.8算术运算符和算术表达式算术运算符和算术表达式(2)(2)算术表达式和运算符的优先级与结合性:算术表达式和运算符的优先级与结合性:用算术运算符和括号将运算对象(也称操作数)连接起来的、符合语法规则的式子,称为算术表达式算术表达式。运算对象包括常量、变量、函数等。例如例如:*.5a 是一个合法的表达式第12页,本讲稿共49页 3.2 3.2 常量与变量常量与变量语言规定了运算符的优先级和结合性。在表达式求值时,先按运算符的优先级别高低次序执行,例如先乘除后加减。规定了各种运算符的结合方向(结合性)算术运算符的结合方向为“自左至右”,即先左后右。第13页,本讲稿共49页 3.8 3.8算术运算符和算术表达式算术运算符和算术表达式(3)(3)强制类型转换运算符强制类型转换运算符 可以利用强制类型转换运算符将一个表达式转换成所需类型。一般形式:(类型名)(表达式)例如:例如:(double)将转换成double类型(int)(x+y)将x+y的值转换成整型(float)(5%3)将5%3的值转换成float型第14页,本讲稿共49页例例3.8 强制类型转换。强制类型转换。#include void ();();printf(x=%f,i=%dn,x,i);说明:说明:说明:说明:有两种类型转换,一种是在运算时不必用户指定,系统自动进行的类型转换,如3+6.5。第二种是强制类型转换。当自动类型转换不能实现目的时,可以用强制类型转换。运行结果:运行结果:x3.600000,i=3第15页,本讲稿共49页#include stdio.hmain()int m=5;printf(m/2=%dn,m/2);printf(float)(m/2)=%fn,(float)(m/2);printf(float)m/2=%fn,(float)m/2);printf(m=%dn,m);第16页,本讲稿共49页 3.8 3.8算术运算符和算术表达式算术运算符和算术表达式(4)(4)自增、自减运算符自增、自减运算符 作用是使变量的值增或减如如:,(在使用之前,先使的值加 (减),(在使用之后,使的值加(减)第17页,本讲稿共49页 3.8 3.8算术运算符和算术表达式算术运算符和算术表达式i+i+与与+i+i的区别:的区别:是先执行后,再使用的值;是先使用的值后,再执行。例如:例如:设i值为 ;i的值先变成4,再赋给,j的值为 ;先将 i的值3赋给,的值为,然后变为第18页,本讲稿共49页 3.8 3.8算术运算符和算术表达式算术运算符和算术表达式注意:注意:(1)自增运算符(),自减运算符(),只能用于变量,而不能用于常量或表达式,(2)和的结合方向是“自右至左”。自增(减)运算符常用于循环语句中使循环变量自动加。也用于指针变量,使指针指向下一个地址 表达式求值举例:设表达式求值举例:设x=2.5,a=7,y=4.7,求表达式,求表达式x+a%3*(int)(x+y)%2/4的值的值第19页,本讲稿共49页 3.8 3.8算术运算符和算术表达式算术运算符和算术表达式(5)(5)有关表达式使用中的问题说明有关表达式使用中的问题说明 ANSI C并没有具体规定表达式中的子表达式的求值顺序,允许各编译系统自己安排。例如:对表达式 a=f1()+f2()并不是所有的编译系统都先调用f1(),然后调用f2()。在有的情况下结果可能不同。有时会出现一些令人容易搞混的问题,因此务必要小心谨慎。第20页,本讲稿共49页 3.8 3.8算术运算符和算术表达式算术运算符和算术表达式语言中有的运算符为一个字符,有的运算符由两个字符组成,为避免误解,最好采取大家都能理解的写法。例如:不要写成i+j的形式,而应写成 (i+)+j的形式 第21页,本讲稿共49页 3.8 3.8算术运算符和算术表达式算术运算符和算术表达式在调用函数时,实参数的求值顺序,标准并无统一规定。例如:例如:的初值为,如果有下面的函数调用:printf(,i+)在有的系统中,从左至右求值,输出“,”。在多数系统中对函数参数的求值顺序是自右而左,函数输出的是“,”。以上这种写法不宜提倡,最好改写成 j=i+;j=i+;printf(%d printf(%d,%d%d,j j,i)i)不要写出别人看不懂的也不知道系统会怎样执行程序第22页,本讲稿共49页 3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 (1)(1)赋值运算符赋值运算符 赋值符号“”就是赋值运算符,它的作用是将一个数据赋给一个变量。如“”的作用是执行一次赋值操作(或称赋值运算)。把常量赋给变量。也可以将一个表达式的值赋给一个变量.第23页,本讲稿共49页 3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 (2)(2)类型转换类型转换 如果赋值运算符两侧的类型不一致,但都是数值型或字符型时,在赋值时要进行类型转换。将浮点型数据(包括单、双精度)赋给整型变量时,舍弃浮点数的小数部分。如如:为整型变量,执行“i=3.56”的结果是使的值为,以整数形式存储在整型变量中.第24页,本讲稿共49页 3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 将整型数据赋给单、双精度变量时,数值不变,但以浮点数形式存储到变量中 如如:将赋给float变量,即执行,先将转换成,再存储在中。将赋给型变量,即执行,则将补足有效位数字为,然后以双精度浮点数形式存储到变量中。第25页,本讲稿共49页 3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 将一个double型数据赋给float变量时,截取其前面7位有效数字,存放到float变量的存储单元(4个字节)中。但应注意数值范围不能溢出。如如:float f;double d=123.456789e100;f=d;就出现溢出的错误。如果将一个float型数据赋给double变量时,数值不变,有效位数扩展到16位,在内存中以8个字节存储第26页,本讲稿共49页 3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 字符型数据赋给整型变量时,由于字符只占1个字节,而整型变量为个字节,因此将字符数据(个二进位)放到整型变量存储单元的低位中。第一种情况:如果所用系统将字符处理为无符号的字符类型,或程序已将字符变量定义为 型,则将字符的位放到整型变量低位,高位补零例如:例如:将字符赋给型变量第27页,本讲稿共49页 3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 第二种情况:如果所用系统(如Turbo C+)将字符处理为带符号的(即signed char),若字符最高位为,则整型变量高位补;若字符最高位为,则高位全补。这称为“符号扩展”,这样做的目的是使数值保持不变,如变量(字符)以整数形式输出为,的值也是。第28页,本讲稿共49页 3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 将一个int、short、long型数据赋给一个char型变量时,只将其低8位原封不动地送到char型变量(即截断)。例如:例如:int i=289;char c=a;c=i;赋值情况:c的值为33,如果用“%c”输出c,将得到字符“!”(其ASCII码为33)。第29页,本讲稿共49页 3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 将带符号的整型数据(int型)赋给long型变量时,要进行符号扩展,将整型数的16位送到long型低16位中:如果int型数据为正值(符号位为),则long型变量的高16位补;如果int型变量为负值(符号位为),则long型变量的高16位补,以保持数值不改变。反之,若将一个long型数据赋给一个int型变量,只将long型数据中低16位原封不动地送到整型变量(即截断)。第30页,本讲稿共49页 3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 例如:例如:int a;long b;a=b;赋值情况如图:p61图3-13如果(八进制数),则赋值后值为。p61图3-14第31页,本讲稿共49页 3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 将unsigned int型数据赋给long int型变量时,不存在符号扩展问题,只需将高位补即可。将一个unsigned类型数据赋给一个占字节数相同的非unsigned型整型变量(例如:unsigned int -int,unsigned long-long,unsigned short-short),将unsigned型变量的内容原样送到非unsigned型变量中,但如果数据范围超过相应整型的范围,则会出现数据错误。第32页,本讲稿共49页 3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 例如:例如:unsigned int 65535;int b;;将整个送到中,由于是int,第位是符号位,因此b成了负数。根据补码知识可知,的值为-1,可以用printf(%d,);来验证。将非unsigned型数据赋给长度相同的unsigned型变量,也是原样照赋(连原有的符号位也作为数值一起传送)。第33页,本讲稿共49页短 长:符号扩展长 短:截断(截取相应长度的低位)由于c语言使用灵活,在不同类型数据之间赋值时,常常会 出现意想不到的结果,而编译系统并不提示出错,全靠程序员的经验来找出问题。这就要求编程人员知道这些赋值规则。在学习这部分内容时不必死记,可以通过学生自学和上机实践来掌握。短短为无符号数、正数为无符号数、正数 长长高位补零高位补零短短为负为负 长长高位补高位补1不同类型的整型数据间的赋值规则归结为:第34页,本讲稿共49页例例3.9 有符号数据传送给无符号变量。有符号数据传送给无符号变量。#include void();(n,);说明:说明:说明:说明:“%u”是输出无符号数时所用的格式符。如果为正值,且在32767之间,则赋值后数值不变。赋值情况见图 运行结果:运行结果:第35页,本讲稿共49页 3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 (3)(3)复合的赋值运算符复合的赋值运算符 在赋值符“”之前加上其他运算符,可以构成复合的运算符。例如例如:等价于 *等价于 *()等价于 以“”为例来说明,它相当于使进行一次自加()的操作。即先使加,再赋给。第36页,本讲稿共49页 3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 为便于记忆,可以这样理解:为便于记忆,可以这样理解:a+=b (其中a为变量,b为表达式)a+=b(将有下划线的“a+”移到“=”右侧)|_ a=a+b(在“=”左侧补上变量名a)第37页,本讲稿共49页 3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 注意注意:如果是包含若干项的表达式,则相当于它有如果是包含若干项的表达式,则相当于它有 括号。括号。如:如:x%=y+3 x%=(y+3)|_ x=x%(y+3)(不要错写成x=x%y+3)凡是二元(二目)运算符,都可以与赋值符一起组合成复合赋值符。语言规定可以使用种复合赋值运算符:语言规定可以使用种复合赋值运算符:,*,|第38页,本讲稿共49页 3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 (4)(4)赋值表达式赋值表达式 由赋值运算符将一个变量和一个表达式连接起来的式子称为“赋值表达式”。一般形式为一般形式为:例如例如:“5”是一个赋值表达式 第39页,本讲稿共49页 3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 对赋值表达式求解的过程是:对赋值表达式求解的过程是:求赋值运算符右侧的“表达式”的值;赋给赋值运算符左侧的变量。例如例如:赋值表达式“=3*5”的值为15,执行表达式后,变量a的值也是15。注意注意:一个表达式应该有一个值一个表达式应该有一个值 第40页,本讲稿共49页 3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 左值左值(lvalue)(lvalue):赋值运算符左侧的标识符变量可以作为左值;而表达式就不能作为左值(如a+b);常变量也不能作为左值,右值右值(lvalue)(lvalue):出现在赋值运算符右侧的表达式 左值也可以出现在赋值运算符右侧,因而左值 都可以作为右值。第41页,本讲稿共49页 3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 赋值表达式中的“表达式”,又可以是一个赋值表达式.例如例如:a=(b=5)分析分析:括弧内的“b=5”是一个赋值表达式,它的值等于5。执行表达式“a=(b=5)”相当于执行“b=5”和“ab”两个赋值表达式。赋值运算符按照“自右而左”的结合顺序,因此,“(b5)”外面的括弧可以不要,即“a=(b=5)”和“a=b=5”等价.第42页,本讲稿共49页 3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 请分析下面的赋值表达式(a=3*5)=4*3分析分析:先执行括弧内的运算,将15赋给a,然后执行4*3的运算,得12,再把12赋给a。最后a的值为12,整个表达式的值为12。可以看到(a=3*5)出现在赋值运算符的左侧,因此赋值表达式(a=3*5)是左值 注意注意:在对赋值表达式(a=3*5)求解后,变量a得到值15执行(a=3*5)=4*3时,实际上是将4*3的积12赋给变量a,而不是赋给3*5。不能写成:a=3*5=4*3第43页,本讲稿共49页 3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 赋值表达式也可以包含复合的赋值运算符。如:如:a+=a-=a*a分析分析:此赋值表达式的求解步骤如下 先进行“*”的运算,它相当于*,a的值为144132。再进行“”的运算,相当于=a+(-132),a的值为132-132-264。第44页,本讲稿共49页 3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 将赋值表达式作为表达式的一种,使赋值操作不仅可以出现在赋值语句中,而且可以以表达式形式出现在其他语句(如输出语句、循环语句等)中.如:如:printf(%d,a=b);分析分析:如果b的值为3,则输出a的值(也是表达式a=b的值)为3。在一个语句中完成了赋值和输出双重功能。第45页,本讲稿共49页 3.10 3.10 逗号运算符和逗号表达式逗号运算符和逗号表达式逗号运算符逗号运算符:将两个表达式连接起来,又称为“顺序求值运算符”如:如:5,一般形式一般形式:表达式,表达式表达式,表达式求解过程:求解过程:先求解表达式,再求解表达式。整个逗号表达式的值是表达式的值。逗号表达式 的值为14第46页,本讲稿共49页 3.10 3.10 逗号运算符和逗号表达式逗号运算符和逗号表达式例:例:逗号表达式*5,*分析分析:赋值运算符的优先级别高于逗号运算符,因此应先求解*5.的值为5,然后求解*,得。整个逗号表达式的值为。一个逗号表达式又可以与另一个表达式组成一一个逗号表达式又可以与另一个表达式组成一个新的逗号表达式个新的逗号表达式 如如:(*,*),先计算出的值等于,再进行*的运算得60(但值未变,仍为15),再进行得,即整个表达式的值为。第47页,本讲稿共49页 3.10 3.10 逗号运算符和逗号表达式逗号运算符和逗号表达式逗号表达式的一般形式可以扩展为 表达式,表达式,表达式,表达式,表达式,表达式,表达式,表达式 它的值为表达式的值。逗号运算符是所有运算符中级别最低的例例:(,*),*3赋值表达式,将一个逗号表达式的值赋给,的值等于 逗号表达式,包括一个赋值表达式和一个算术表达式,的值为,整个逗号表达式的值为18。第48页,本讲稿共49页3.10 3.10 逗号运算符和逗号表达式逗号运算符和逗号表达式注意注意:并不是任何地方出现的逗号都是作为逗号运算符。例如函数参数也是用逗号来间隔的。如如:printf(“%d,%d,%d”,a,b,c);“,”并不是一个逗号表达式,它是printf函数的3个参数printf(“%d,%d,%d”,(a,b,c),b,c)“(,)”是一个逗号表达式,它的值等于的值。第49页,本讲稿共49页