基本数据类型表达式与运算符.ppt
C语言程序设计教程语言程序设计教程第二章第二章 基本数据类型、运算基本数据类型、运算符与表达式符与表达式1C语言程序设计教程语言程序设计教程本章要求:本章要求:C语言的数据类型语言的数据类型各种类型数据的定义方法各种类型数据的定义方法常量与变量常量与变量各种类型数据的混合运算各种类型数据的混合运算强制类型变换强制类型变换重点:重点:数据类型;数据类型;数据的定义方法;数据的定义方法;各种类型数据的混合运算各种类型数据的混合运算2C语言程序设计教程语言程序设计教程2.1 C语言的数据类型 C语言支持的数据类型非常丰富,它包括:基本数据类型,构造数据类型,指针类型,空类型四大类 数据类型数据类型构造类型构造类型指针类型指针类型*空空类类型型(无无值值类类型型)voidvoid枚举类型枚举类型 enum enum数组类型数组类型 结构体类型结构体类型 struct struct共用体类型共用体类型 union union基本类型基本类型整型整型 int int字符型字符型 char char实型(浮点型)实型(浮点型)单精度实型单精度实型 float float双精度实型双精度实型 double3C语言程序设计教程语言程序设计教程2.2 常量、变量和标识符常量、变量和标识符对于基本数据类型量,根据其取值是否可改变可分为常量和变量两种。1.常量常量:其值不发生改变的量称为常量。常量可与数据类型结合起来分类。例如,整型常量、实型常量、字符型常量、字符串常量和符号常量。在编程过程中,常量是可以不经说明而直接引用的,而变量则必须要先定义后使用。常用常量如下所示:整型常量:25、0、-7;实型常量:5.6、-6.9;字符常量:a、b。4C语言程序设计教程语言程序设计教程2.标识符标识符是用来标识变量名、符号常量名、函数名、数组名、类型名、文件名的有效字符序列。用一个标识符来表示一个常量,称之为符号常量。符号常量在使用之前必须先定义,其一般形式为:#define 标识符 常量其中#define也是一条预处理命令(预处理命令都以#开头),称为宏定义命令其功能是把该标识符定义为其后的常量值。一经定义,以后在程序中所有出现该标识符的地方均代之以该常量值。一般习惯上符号常量的标识符用大写字母,变量标识符用小写字母,以示区别。5C语言程序设计教程语言程序设计教程例2.1符号常量的使用。#define LENGTH 30#include void main()int area,width;width=10;area=width*LENGTH;printf(“area=%d”,area);程序运行结果:程序运行结果:area=300程序分析:程序分析:使用符号常量参与运算,符号常量与变量不同,它的值使用符号常量参与运算,符号常量与变量不同,它的值在其作用域内不能改变,也不能再被赋值。使用符号常量在其作用域内不能改变,也不能再被赋值。使用符号常量的好处是:含意清楚;能做到的好处是:含意清楚;能做到“一改全改一改全改”。6C语言程序设计教程语言程序设计教程3.变量变量,其值可以改变的量称为变量。一个变量应该有一个名字,在内存中占据一定的存储单元。变量在使用之前必须进行定义即为每个变量取一个名称(变量名),同时规定它的数据类型,以便编译时根据数据类型分配存储空间。C语言规定标识符只能由字母、数字和下划线3种字符组成,且第一个字符必须是字母或者下划线。下面标识符的写法是合法的,可以作为变量名使用。Sum,Class_2,data,wang_ming,_high,a8,AREA,year_month_day下面是不合法的标识符和变量名:*data1,99sum,%yuan,$BGss,MR.tom,a1b1,s/t注意,编译系统区分大小写,将它们认为是两个不同的字符。所以,max和MAX是两个不同的变量。7C语言程序设计教程语言程序设计教程注意建议变量名的长度最好不要超过8个字符。在选择变量名和其它标识符时应“见名知意”。要求对所有用到的变量作强制定义,也就是“先定义,后使用”。变量定义一般放在函数体的开头部分。要区分变量名和变量值是两个不同的概念。data 变量名变量名56变量值变量值存储单元变量名存储单元变量名8C语言程序设计教程语言程序设计教程变量名实际上就是以一个名字对应,代表一个地址。在对程序编译连接时由编译系统给每个变量名分配对应的内存地址。变量在定义时必须指定其数据类型,以便在编译时为其分配存储单元。|&a 2500H|2501H|-1250 -a=1250&b2502H|2503H|-2504H|-123.67-b=123.67 2505H|-2506H|变量名、变量值、变量地址间的关系变量名、变量值、变量地址间的关系例如:例如:int a=1250;int a=1250;float b=123.67;float b=123.67;9C语言程序设计教程语言程序设计教程4.变量赋初值C语言中可有多种方法为变量提供初值。可以在变量定义的同时给变量赋以初值的方法。这种方法称为初始化。在变量定义中赋初值的一般形式为:类型说明符 变量1=值1,变量2=值2,;例如:int a=68;/*指定a为整型变量,初值为68*/也可以使被定义的变量的一部分赋初值。例如float b,c,d=7.9;上式指定b,c,d为单精度实型变量,只对d初始化,其值为7.9。如果对几个变量赋予相同的初值,应写为:int e=50,f=50,g=50;10C语言程序设计教程语言程序设计教程例2.2部分初始化数据程序运行结果:a=6,b=14,c=8程序分析:对定义的整型变量进行部分初始化,然后参与运算,并输出结果。#include void main()int a=6,b,c=8;b=a+c;printf(a=%d,b=%d,c=%dn,a,b,c);11C语言程序设计教程语言程序设计教程5.变量的地址在定义了一个变量后,在内存中会分配相应的存储单元,将变量的值存储到该单元中。如前所述注意区分变量名和变量值这两个不同的概念。例如:int x;float y;x=3;y=3.14159;200020012002200320042005xy200633.1415912C语言程序设计教程语言程序设计教程2.3简单数据类型与表示范围简单数据类型与表示范围2.3.1 整型数据1.整型常量的表示方法整型常量就是整常数。在语言中,经常使用的整常数有三种进制,它们分别是八进制、十六进制和十进制。八进制前缀为“0”,十六进制前缀为“0 x”,十进制无前缀。(1)(1)十进制整数。十进制整数。如:如:123,-456.4123,-456.4。(2)(2)八进制整数。以八进制整数。以0 0头的数是八进制数。头的数是八进制数。如:如:01230123表示八进制数表示八进制数123123,等于十进制数,等于十进制数83,-83,-011011表示八进制数表示八进制数-11,-11,即十进制数即十进制数-9-9。13C语言程序设计教程语言程序设计教程(3)(3)十六进制整数。以十六进制整数。以0 x0 x开头的数是开头的数是1616进制数。进制数。如:如:0 x1230 x123,代表,代表1616进制数进制数123,123,等于十进制数等于十进制数 291 291。-0 x12-0 x12等于十进制数等于十进制数1818。(4)(4)整型常数的后缀:整型常数的后缀:基本整型的长度为基本整型的长度为1616位,十进制无符号整常数的范围位,十进制无符号整常数的范围为为0 06553565535,有符号数为,有符号数为-32768-32768+32767+32767。八进制无符号数的表示范围为八进制无符号数的表示范围为0 001777770177777。十六进制无符号数的表示范围为十六进制无符号数的表示范围为0X00X00XFFFF0XFFFF或或0 x00 x00 xffff0 xffff。如果使用的数超过了上述范围,就必须加上后缀如果使用的数超过了上述范围,就必须加上后缀“L”“L”或或“l”“l”变为长整型数来表示。变为长整型数来表示。例如:例如:567L(567L(十进制为十进制为567)567)注意:注意:长整数长整数567L567L和基本整常数和基本整常数567567在数值上并无区别,在数值上并无区别,但是所占存储空间大小不同。对但是所占存储空间大小不同。对567L567L而言,因为是长而言,因为是长整型量,编译系统将为它分配整型量,编译系统将为它分配4 4个字节存储空间。而个字节存储空间。而对对567567,因是基本整型,则只分配,因是基本整型,则只分配2 2个字节的存储空间。个字节的存储空间。14C语言程序设计教程语言程序设计教程2.整型变量(1)整型数据在内存中的存放形式数据在计算机内存中是以二进制形式存放的,例如,定义了一个整型变量a:int a;/*定义a为整型变量*/a=11;/*给a附以初值11*/由于在内存中数值是以补码表示的,正整数的补码和它的原码在二进制形式上是相同的。所以,a11,在内存中的存放形式如下所示。内存中内存中图图a 110 0 0 0 0 0 0 0 0 0 0 0 1 0 1 115C语言程序设计教程语言程序设计教程负数的补码:将该数的绝对值的二进制形式按位取反后再加1。例如:求-11的补码:符号位符号位(2)整型的分类基本型:类型说明符为int,在内存中占2个字节。短整量:类型说明符为short int或short。所占字节和取值范围均与基本型相同。长整型:类型说明符为long int或long,在内存中占4个字节。16C语言程序设计教程语言程序设计教程有符号型:类型说明符为signed;无符号型:类型说明符为unsigned。有符号型与无符号型又可与前三种类型匹配而构成:类型名称类型说明符数值范围字节数有符号基本型 signed int-32768327672无符号基本型unsigned int0655352有符号短整型 signed short int-32768327672无符号短整型unsigned short int0655352有符号长整型signed long int-214748364821474836474无符号长整型 unsigned long int042949672954上面带 的部分表示其内容可以省略 17C语言程序设计教程语言程序设计教程(3)整型变量的定义变量定义的格式为:类型说明符 变量名标识符,变量名标识符,.;说明:允许在一个类型说明符后,定义多个相同类型的变 量,并使用逗号分割变量名中多个变量,使用分号结 束。类型说明符与变量名之间至少用一个空格间隔。变量定义必须放在变量使用之前。一般放在函数体的开头部分。在程序的同一部分,禁止对同一变量进行重复定义,在书写不同种类型变量定义时,避免都写在一行上。对所用到的变量必须进行强制定义,即“先定义,后使用”。int a,b,c;/*a,b,c为整型变量*/long x,y;/*x,y为长整型变量*/18C语言程序设计教程语言程序设计教程例2.3整型变量的定义与使用#includevoid main()long a,b;int x,sum,ave;/*定义整型变量x,sum,ave*/unsigned y;/*定义无符号整型变量y*/a=9;x=-10;y=20;b=x+a;sum=x+y;ave=(x+y)/2;/*不同类型数据间可进行运算*/printf(b=x+a=%ld,sum=%d,average=%dn,b,sum,ave);程序运行结果:b=x+a=-1,sum=12,average=6 19C语言程序设计教程语言程序设计教程(4)整型数据的溢出每个整型数据都有其自身的数据类型,有其自身所占存储空间大小,基本整型int定义的变量的最大允许存储值为32767 例3.4整型数据的溢出#includevoid main()int x,y;x=32767;y=x+1;printf(%d,%dn,x,y);程序运行结果:32767,-32768程序分析:计算结果-32768与实际应该的结果32768相差一个符号,为什么呢?数据在内存中都是以该数的补码的二进制形式存放的,32767的补码为0111 1111 1111 1111,加1后发生进位,变成1000 0000 0000 0000,最高位的1占据了符号位,而它正好是-32768的补码形式,所以才有上述输出结果。20C语言程序设计教程语言程序设计教程实型数据1实型数据表示方法 实型也称为浮点型。语言中,实数有二种形式:十进制小数形式和指数形式。十进制数形式:由数字09和小数点组成。注意,必须有小数点,且小数点的前面或后面必须有数字。例如:3.1415926,0.0、0.1、7.0、780.、-25.860等均为合法的实数。指数形式:由十进制数(基数)、加阶码标志“e”或“E”以及指数(阶码,只能为整数,可以带符号)组成。其一般形式为:a E n(a为十进制数基数,n为十进制整数阶码)其值为 a*10n。如:1.6E2(等于1.6*102)注意:阶码标志e(或E)之前必须有数字,且e后的指数必须为整数。21C语言程序设计教程语言程序设计教程2.实型数据在内存中的存放形式实型数据一般占4个字节(32位)内存空间。与整型数据的存储方式不同,系统把一个实型数据分为小数部分和指数部分分别存放。指数部分采用规范化的指数形式表示。例如,实数7.15731在内存中的存放形式如下:图中是用十进制形式来表示的,实际上计算机中是用二进制来表示小数部分,以及用2的幂次来表示指数部分的。1+.715731+数符 小数部分 指符 指数 .715731(101)0.71573122C语言程序设计教程语言程序设计教程3.实型变量的分类实型变量分为:单精度(float型)、双精度(double型)和长双精度(long double型)三类。类型说明符比特数(字节数)有效数字数的范围float32(4)6710-371038 double64(8)151610-30710308 long double 128(16)181910-4931104932 实型变量定义,例如:float x,y;/*x,y为单精度实型量*/double a,b,c;/*a,b,c为双精度实型量*/long double z;/*z为长双精度实型量*/23C语言程序设计教程语言程序设计教程4.实型数据的舍入误差由于实型变量的存储单元能提供的有效数字总是有限的,其中单精度的有效数字是7为,双精度的是16位。在有效位数之外的数字将被舍去,因此会产生误差。例2.5 实型数据的舍入误差。#includevoid main()float x,y;x=7654321.152e3;y=x+33;printf(%f,%fn,x,y);程序运行结果:7654321152.000000,7654321152.000000“f”是输出实数的制定格式。结果中xy,单精度的x较33大的多,其有效位数是7位,超过此范围的数字是无意义的。Turbo C 规定小数后最多保留六位。应避免这种被“忽视”的情况发生。24C语言程序设计教程语言程序设计教程5.实型常数的类型实型常数不分单、双精度,都按双精度double型处理。例如定义一个实型变量a,进行如下运算:a3.14159*7.1617编译系统先将3.14159和7.1617作为双精度数进行相乘的运算,得到的结果也是双精度的,然后取其前7位有效数字赋值给实型变量a。这样,可以使计算的结果更加精确。25C语言程序设计教程语言程序设计教程2.3.3 字符型数据和字符串常量字符型数据包括字符常量和字符变量。1.字符常量字符常量是用一对单引号括起来的一个字符。例如:x、d、=、!等都是合法字符常量。注意:d和D是两个不同的字符常量。注意:字符常量只能是单个字符,不能是字符串。字符可以是字符集中除了单引号本身“”、双引号“”、反斜杠“”外的任意字符。但数字被定义为字符型之后就不能参与数值运算。如6和6 是不同的。6是字符常量,不能参与运算。a,A,1a,A,1abcabc、“a”“a”26C语言程序设计教程语言程序设计教程2.转义字符转义字符以反斜线“”开头,后跟一个或几个字符。转义字符具有特定的含义,不同于字符的原意,故称“转义”字符。如,输出函数中用到的“n”其意义是“回车换行”C语言中,转义字符有三种:简单转义字符、八进制转义字符和十六进制转义字符。n n 换行换行 t t 横向跳格(水平制表横向跳格(水平制表8 8列)列)r r 回车回车 反斜杠反斜杠 单引号单引号 ”双引号双引号 dddddd ddd ddd表示表示1 1到到3 3位八进制数字位八进制数字 xhhxhh hh hh表示表示1 1到到2 2位十六进制数字位十六进制数字27C语言程序设计教程语言程序设计教程例2.6 转义字符的使用。程序运行结果:fgcde#includevoid main()printf(“abctderfbgn”);程序分析:注意:转义字符的作用。首先在左端输出“abc”,然后遇到“t”,它的作用是跳到下一个制表符位置;一个制表符占8列,下一制表符位置从第9列开始,故在第910列上输出“de”;然后遇到“r”,它代表“回车”(不换行),于是返回到本行的行首(最左端第1列),输出“f”;然后遇到“b”,它代表“退一格”,接着输出“g”。程序运行时的输出结果为:fabgcde但显示器上看到的结果与上述结果不同,为:fgcde中间的字符被后续字符取代了。28C语言程序设计教程语言程序设计教程3.字符变量字符变量用来存储字符常量,它只能存放一个字符。字符变量的类型说明符是char。字符变量类型定义的格式和书写规则都与整型变量相同。例如:char a,b;4.在内存中的存储形式每个字符变量被分配一个字节的内存空间,字符型数据在存储时,并不是把该字符本身放到内存单元中,而是把该字符的ASCII码值存放在变量的内存单元之中的。例如:A的十进制ASCII码是65,a的十进制ASCII码是97 29C语言程序设计教程语言程序设计教程在内存单元中存放的是65和97的二进制代码:字符型数据在内存中是以ASCII码存放的,它的存储形式与整数的存储形式类似。使得字符型数据和整型数据之间可以通用。语言允许对整型变量赋以字符值,也允许对字符变量赋以整型值。在输出时,允许把字符变量按整型量输出,也允许把整型量按字符量输出。30C语言程序设计教程语言程序设计教程例2.7 向字符变量与整型数据通用程序运行结果:a,A 65,97#includevoid main()char a,b;a=65;b=97;printf(%c,%cn,a,b);printf(%d,%dn,a,b);a,b值的输出形式取决于printf函数格式串中的格式符,当格式符为%c时,对应输出的变量值为字符,当格式符为%d时,对应输出的变量值为整数。由此可知,字符型数据和整型数据是可以通用的,但要注意字符型数据只占一个字节,它只能存放0-255范围的整数。31C语言程序设计教程语言程序设计教程例2.8 大小写字母的转换程序运行结果:A,b65,98#includevoid main()char a,b;a=a;b=B;a=a-32;b=b+32;printf(%c,%cn%d,%dn,a,b,a,b);a,b为字符变量并赋予字符值,语言允许字符变量参与数值运算,即用字符的ASCII码值参与运算。大小写字母的ASCII 码值相差32,因此可以将小写字母与大写字母进行相互转换,然后分别以字符型和整型输出。32C语言程序设计教程语言程序设计教程5.字符串常量 字符常量是用一对单引号括起来的一个字符,而字符串常量则是由一对双引号括起的字符序列。例如:“chongqing”,“C program”,“&1.75”,“a”等都是合法的字符串常量。字符串常量和字符常量是不同的量。它们之间的主要区别如下:外形不同,字符常量由一对单引号括起来,字符串常量由一对双引号括起来。注意,a和a是不同的。内容不同,字符常量只能是单个字符,字符串常量则可以含一个或多个字符。单向赋值,可以把一个字符常量赋予一个字符变量,但不能把一个字符串常量赋予一个字符变量。空间不同,字符常量占一个字节的内存空间,字符串常量占的内存字节数等于字符串中字节数加1。末尾增加的一个字节用于存放字符串结束的标志字符0(ASCII码为0)。33C语言程序设计教程语言程序设计教程字符串 chongqing 的长度是9个字节,在内存中所占的字节为10,其存储方式如下图所示:最后一个字符为0,在输出时是不会输出0的。注意在书写程序时不必加0,0是系统自动加上的。字符常量a和字符串常量a虽然都只有一个字符,但在内存中的情况是不同的。a在内存中占一个字节,a在内存中占二个字节。34C语言程序设计教程语言程序设计教程2.3.4 各数据类型间的混合运算 整型(包括int,short,long)、浮点型(包括float,double)可以混合运算。在进行运算时,不同类型的数据要先转换成同一类型,然后进行运算.转换的原则就是为了两个运算对象的计算结果尽可能提供多的存储空间。当运算符两端的运算对象的数据类型不一致时,在运算前先将类型等级较低的数据转换成等级较高的数据保值转换。上述的类型转换是由系统自动进行的.doubledoublefloatfloatlonglongunsignedunsignedintintChar,shortChar,short高高低低横向向左的箭头表示必定的转换 纵向的箭头表示数据类型级别的高低,实际运算时不需逐级转换,可由级别低的直接转换为级别高的。35C语言程序设计教程语言程序设计教程赋值号两边量的数据类型不同时,赋值号右边量的类型将转换为左边量的类型。如果右边量的数据类型长度左边长时,将丢失一部分数据,这样会降低精度,丢失的部分按四舍五入向前舍入。例3.9 数据类型转换#includevoid main()float PI=3.14159;int s,r=5;s=r*r*PI;printf(s=%dn,s);程序运行结果:s=78PI为实型;s,r为整型。在执行s=r*r*PI语句时,r和PI都转换成double型计算,结果也为double型。但由于s为整型,故赋值结果仍为整型,舍去了小数部分。36C语言程序设计教程语言程序设计教程2.3.5 简单数据类型的表示范围 类型说明符字节数值范围字符型char1C字符集基本整型int2-3276832767短整型short int2-3276832767长整型long int4-214783648214783647无符号型unsigned2065535无符号长整型 unsigned long404294967295单精度实型float43/4E-383/4E+38双精度实型double81/7E-3081/7E+30837C语言程序设计教程语言程序设计教程2.3.6 数据的简单输出将数据结果展示出来,必须使用输出语句,所谓输入输出是以计算机为主体而言的。在语言中,所有的数据输入输出都是由库函数完成的。在使用语言库函数时,要用预编译命令#include将有关“头文件”包括到源文件中。使用标准输入输出库函数时要用到“stdio.h”文件,因此源文件开头应有以下预编译命令:#include 或#include stdio.h“stdio是standard input&outupt的英文缩写,其意思是标准输入输出。38C语言程序设计教程语言程序设计教程printf函数调用的一般形式为:printf(格式控制字符串,输出表列)其中“格式控制字符串”用于指定输出格式。“格式控制字符串”可由格式字符串和非格式字符串两种组成。格式字符串是以%开头的字符串,在%后面跟有各种格式字符,以说明输出数据的类型、形式、长度、小数位数等。如:“%d”表示按十进制整型输出;“%ld”表示按十进制长整型输出;“%c”表示按字符型输出等。“%f”表示按小数形式输出单、双精度实数非格式字符串在输出时原样照印,在显示中起提示作用。输出表列中给出了各个输出项,要求格式字符串和各输出项在数量和类型上应该一一对应。39C语言程序设计教程语言程序设计教程例2.10 数据输出程序运行结果:程序运行结果:68 8068 8068,8068,80D,PD,Pa=68,b=80a=68,b=80 x is 3.140000 x is 3.140000#includevoid main()int a=68,b=80;float x=3.14;printf(%d%dn,a,b);printf(%d,%dn,a,b);printf(%c,%cn,a,b);printf(a=%d,b=%dn,a,b);printf(x is%fn,x);输出第一句中,在两%d 之间加了一个空格(非格式字符),所以输出的a,b值之间有一个空格。第二句中加入的是非格式字符逗号,因此输出的a,b间加了一个逗号。第三句要求按字符型输出a,b值。第四句中为了提示输出结果又增加了非格式字符串。第五句的格式串要求按实型输出,其他非格式字符按原型输出。40C语言程序设计教程语言程序设计教程2.4 C语言的运算符与表达式语言的运算符与表达式2.4.1 C语言运算符简介1.运算符C语言的运算符可分为算术运算符、赋值运算符、关系运算符、逻辑运算符、位运算符、条件运算符、逗号运算符及一些特殊的运算符。按运算符与运算对象(操作数)的关系可将C语言的运算符分为单目运算符、双目运算符和三目运算符。单目运算符是指运算符只需要一个操作数,如!,+,-等;双目运算符是指运算符需要两个操作数,即运算符的左右两侧都需要一个操作数,如+,-,*,/,等;三目运算符是指运算符需要三个操作数,如条件运算符?:。41C语言程序设计教程语言程序设计教程语言的运算符可分为以下几类:算术运算符:用于各类数值运算。包括加(+)、减(-)、乘(*)、除(/)、求余(或称模运算,%)、自增(+)、自减(-)共七种。关系运算符:用于比较运算。包括大于()、小于(=)、小于等于(=)和不等于(!=)六种。逻辑运算符:用于逻辑运算。包括与(&)、或(|)、非(!)三种。位操作运算符:参与运算的量,按二进制位进行运算。包括位与(&)、位或(|)、位非()、位异或()、左移()赋值运算符:用于赋值运算,分为简单赋值(=)、复合算术赋值(+=,-=,*=,/=,%=)和复合位运算赋值(&=,|=,=,=,=)条件运算符:这是一个三目运算符,用于条件求值(?:)。逗号运算符:用于把若干表达式组合成一个表达式(,)。指针运算符:用于取内容(*)和取地址(&)二种运算。求字节数运算符:用于计算数据类型所占的字节数(sizeof)。强制类型转换运算符:强制进行数据类型转换(类型)。分量运算符:用于存取结构和联合中的成员(,.),其优先级在所有运算符中是最高的。下标运算符:用于数组下标的表示().其他运算符:如函数调用运算符(())。42C语言程序设计教程语言程序设计教程2.表达式表达式是使用运算符和圆括号将操作数连接起来构成的式子。C语言的操作数包括常量、变量、函数值等。例如:表达式(x-y)/(3*a+b)-6*d中包括+,-,/,*等运算符,操作数包括x,y,a,b,3等。语言的运算符不仅具有不同的优先级,而且还有一个特点,就是它的结合性。3.简单语句C语言中,在表达式的末尾加上一个分号“;”就构成了简单语句。在程序设计过程中要避免使用无意义的简单语句。43C语言程序设计教程语言程序设计教程1.赋值运算符赋值就是将一个数据值存储到一个变量中。注意,赋值的对象只能是变量,而这个数据值既可以是常量,也可以是变量,还可以是有确定值的表达式。赋值运算符记为“=”,其作用是将一个数据赋给一个变量。例如,“a3;”其作用是执行一次赋值操作,表示将常量3赋给变量a。2.赋值表达式由赋值运算符“=”将一个变量和表达式连接的式子称为赋值表达式。其一般形式为:变量=表达式例如:x=sin(a)+(i+);赋值运算符和赋值表达式赋值运算符和赋值表达式44C语言程序设计教程语言程序设计教程对赋值表达式求解的过程是:对赋值表达式求解的过程是:求赋值运算符右侧的求赋值运算符右侧的“表达式表达式”的值的值;赋给赋值运算符左侧的变量。赋给赋值运算符左侧的变量。例如例如:赋值表达式赋值表达式“=3*5”=3*5”的值为的值为1515,执行表达式后,变量,执行表达式后,变量a a的值也是的值也是1515。注意注意:一个表达式应该有一个值一个表达式应该有一个值 45C语言程序设计教程语言程序设计教程左值左值(lvalue)(lvalue):赋值运算符左侧的标识符赋值运算符左侧的标识符变量可以作为左值变量可以作为左值;而表达式就不能作为左值而表达式就不能作为左值(如如a+b);a+b);常变量也不能作为左值,常变量也不能作为左值,右值右值(rvalue):(rvalue):出现在赋值运算符右侧的表达式出现在赋值运算符右侧的表达式 左值也可以出现在赋值运算符右侧,因而左值左值也可以出现在赋值运算符右侧,因而左值 都可以作为右值。都可以作为右值。赋值表达式中的赋值表达式中的“表达式表达式”,又可以是一个赋值表达式,又可以是一个赋值表达式.例如例如:a=(b=5)a=(b=5)分析分析:括弧内的括弧内的“b=5”“b=5”是一个赋值表达式,它的值等于是一个赋值表达式,它的值等于5 5。执行表达式。执行表达式“a=(b=5)”“a=(b=5)”相当于执行相当于执行“b=5”“b=5”和和“a“ab”b”两个赋值表达式。两个赋值表达式。赋值运赋值运算符算符按照按照“自右而左自右而左”的结合顺序,因此,的结合顺序,因此,“(b“(b5)”5)”外面的括弧可以不要,外面的括弧可以不要,即即“a=(b=5)”“a=(b=5)”和和“a=b=5”“a=b=5”等价,最后等价,最后a a5 5。46C语言程序设计教程语言程序设计教程请分析下面的赋值表达式请分析下面的赋值表达式(a=3*5)=4*3(a=3*5)=4*3分析分析:先执行括弧内的运算,将先执行括弧内的运算,将1515赋给赋给a a,然后执行,然后执行4*34*3的运算,得的运算,得1212,再把,再把1212赋给赋给a a。最后。最后a a的值为的值为1212,整个表达式的值为整个表达式的值为1212。可以看到。可以看到(a=3*5)(a=3*5)出现在赋出现在赋值运算符的左侧,因此赋值表达式值运算符的左侧,因此赋值表达式(a=3*5)(a=3*5)是左值是左值 注意注意:在对赋值表达式在对赋值表达式(a=3*5)(a=3*5)求解后,变量求解后,变量a a得到值得到值1515,执行,执行(a=3*5)=4*3(a=3*5)=4*3时,实际上是将时,实际上是将4*34*3的积的积1212赋给变量赋给变量a a,而不是赋给而不是赋给3*53*5。不能写成不能写成:a=3*5=4*3a=3*5=4*347C语言程序设计教程语言程序设计教程 将赋值表达式作为表达式的一种,使赋值操作不仅可以出将赋值表达式作为表达式的一种,使赋值操作不仅可以出现在赋值语句中,而且可以现在赋值语句中,而且可以以表达式以表达式形式出现在其他语形式出现在其他语句(如输出语句、循环语句等)中句(如输出语句、循环语句等)中.如:如:printf(%dprintf(%d,a=b);a=b);分析分析:如果如果b b的值为的值为3 3,则输出则输出a a的值的值(也是表达式也是表达式a=ba=b的值的值)为为3 3。在一个语句中完成了赋值和输出双。在一个语句中完成了赋值和输出双重功能。重功能。48C语言程序设计教程语言程序设计教程3.类型转换 如果赋值运算符两边的数据类型不相同,系统将自动进行类型转换,即把赋值号右边的类型换成左边的类型。具体规定如下:(1)整型数与实型数之间的转换将实型数据(单、双精度)赋予整型变量时,舍去实型数据的小数部分。例如:整型变量i,执行“i=3.14”的结果是使得i的值为3,以整数形式存储在内存中。将整型数据赋给实型(单、双精度)变量时,数值不变,但以实型数据形式存储在内存中,即增加小数部分(小数部分的值为0)。49C语言程序设计教程语言程序设计教程(2)实型数据之间的转换将一个double型数据赋给float型变量时,截取其前7位有效数字,存放到float型变量的存储单元(32位)中。注意,数值范围不能溢出。例如:float a;double b=123.456789e100;a=b;便会出现溢出错误。将一个float型数据赋给double型变量时,其数值不变,有效位数扩展到16位,在内存中以64位存储。50C语言程序设计教程语言程序设计教程(3)整型数与字符型数之间的转换字符型数据赋给整型变量时,由于字符型只占一个字节,而整型占二个字节,故将字符的ASCII码值放到整型量的低八位中,这时有两种情况:如所用系统将字符型数据处理为无符号型的量或对unsigned int型变量赋值,则将字符型数据(8位二进制位)放到整型变量的低8位,高8位补为0。例如将字符376(代表图形字符“”,其ASCII码值为254)赋给int型变量a,如下图所示。11 11 11 1011 11 11 10376376a a0 0 00 00 00 11 11 11 100 0 00 00 00 11 11 11 1051C语言程序设计教程语言程序设计教程如所用系统(如Turbo C+3.0)将字符型数据处理为带符号型的量(即signed char),如字符最高位为0,则整型变量高8位补0;如字符最高位为1,则高8位全补1,见下图所示。这称为“符号扩展”,这样做的目的是使数值保持不变,如上述字符/376以整数形式输出为2,a的值也是2。1 1 11 11 101 1 11 11 10376376a a1 1 11 11 11 11 11 11 101 1 11 11 11 11 11 11 101 1 11 11 101 1 11 11 10376376a a1 1 11 11 11 11 11 11 101 1 11 11 11 11 11 11 101 1 11 11 101 1 11 11 10376376a a1 1 11 11 11 11 11 11 101 1 11 11 11 11 11 11 1052C语言程序设计教程语言程序设计教程将一个int、short、long型数据赋给一个char型变量时,只将其低8位原封不动地送到char型变量(截断)。例如:int a=291;char b=c;b=a;赋值情况见下图所示,字符变量b的值为35,如用“c”格式输出b,将得到字符“”(其ASCII为35)。0 0 1 0 0 0 1 10 0 1 0 0 0 1 1i=291i=2910 0 0 0 0 0 0 1 0 0 1 0 0 0 1 10 0 0 0 0 0 0 1 0 0 1 0 0 0 1 1b=35b=3553C语言程序设计教程语言程序设计教程(4)整型数据之间的转换如将带符号的整型数据(int型)赋给long型变量时,要进行符号扩展,将整型数的16位送到long型低16位中。如int型数据为正值(符号位为0),则long型变量的高16位补0;如int型变量为负值(符号位为1),则long型变量的高16位补1,以保证数值不改变。如将一个long型数据赋给一个int型变量,只将long型数据中低16位原封不动地送到int型变量(截断)。例如:int x;long y=9;x=y;赋值情况如下图所示,54C语言程序设计教程语言程序设计教程如果y=65536(八进制数0200000),则在赋值后x值为0,如下图所示。0 0 00 00 00 00 00 00 00 00 00 00 00 00 00 10 010 0 00