




已阅读5页,还剩15页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第三章 数据类型、运算符与表达式本章重点和难点: 掌握各种数据类型及其间的相互转换; 掌握常量、变量的定义; 掌握各种运算符及表达式的构成; 掌握数据的输入与输出。3.1 C语言的数据类型一个程序应包括对数据的描述和对数据处理的描述。1对数据的描述,即数据结构。在C语言中,系统提供的数据结构,是以数据类型的形式出现的。2对数据处理的描述,即计算机算法。算法是为解决一个问题而采取的方法和步骤,是程序的灵魂。为此,著名计算机科学家提出一个公式: 数据结构 + 算法 = 程序 实际上,一个程序除了数据结构和算法外,还必须使用一种计算机语言,并采用结构化方法来表示。C语言提供的数据结构,是以数据类型形式出现的。具体分类如下:单精度实型 (float)双精度实型 (double)字符型 (char)枚举类型数组类型结构体类型共用体类型实型基本类型构造类型指针类型数据类型整型 (int)C语言中的数据,有常量和变量之分,它们分别属于上述这些类型。本章将介绍基本类型中的整型、实型和字符型三种数据。3.2 常量和变量一、 常量1.常量的概念 在程序运行过程中,其值不能被改变的量称为常量。2.常量的分类 (1)整型常量:15,-20 (2)实型常量:-0.2 , 1.56 ,2E+3 (2x103) (3)字符常量:a ,9, *,# (4)字符串常量:“I love china.”, “a” 常量的类型,可通过书写形式来判别。3.符号常量:用一个标识来代表一个常量 使用方法: #define标识符名值例: #define PRICE 30 main( ) int num,total; num = 10 ; total = num * PRICE ; printf(“total=%dn”,total); 符号常量在某作用域内不能再重新赋值,例如,在程序中添加:PRICE40即为错误。符号常量名以大写表示。二、变量1. 变量的概念 在程序运行过程中,其值可以被改变的量称为变量。2. 变量的三个要素(1)变量名:每个变量都必须有一个名字变量名,变量命名遵循标识符命名规则。(3)变量数据类型:说明数据类型是为变量分配相应空间的存储单元,在该存储单元中存放变量的值。(2)变量值:在程序运行过程中,变量值存储在内存中为其开辟的存储单元。在程序中,通过变量名来引用变量的值。1)、变量名实际上是以一个名字对应,代表一个地址;2)、在对程序编译连接时由编译系统给每一个变量名分配对应的存储单元;3)、从变量中取值,实际上是通过变量名找到相应的内存地址,从该存储单元中读取数据;.标识符命名规则(1)有效字符:只能由字母、数字和下划线组成,且以字母或下划线开头。如:sum,average, _total, class, day, month, student_name,tan,lotus_1_2_3,basic, li_ling 下面是不合法的标识符和变量名:dohn,y 123,33,3d64,ab, int(2)有效长度:随系统而异,但至少前个字符有效。如果超长,则超长部分被舍弃。例如,由于student_name和student_number的前个字符相同,有的系统认为这两个变量,是一回事而不加区别。在TC V2.0中,变量名(标识符)的有效长度为个字符,缺省值为。(3)C语言的关键字不能用作变量名。注意:C语言对英文字母的大小敏感,即同一字母的大小写,被认为是两个不同的字符。习惯上,变量名和函数名中的英文字母用小写,以增加可读性。思考题:在C语言中,变量名total与变量名TOTAL、ToTaL、tOtAl等是同一个变量吗?标识符命名的良好习惯见名知意:所谓“见名知意”是指,通过变量名就知道变量值的含义。通常应选择能表示数据含义的英文单词(或缩写)作变量名,或汉语拼音字头作变量名。例如,name/xm(姓名)、sex/xb(性别)、age/nl(年龄)、salary/gz(工资)。4.变量的定义与初始化在语言中,要求对所有用到的变量,必须先定义、后使用;且称在定义变量的同时进行赋初值的操作为变量初始化。(1)变量定义的一般格式 存储类型 数据类型 变量名, 变量名2;例如,int radius, length, area;(2)变量初始化的一般格式存储类型 数据类型 变量名=初值, 变量名2=初值2;例如,int radius=2, length, area; 在C语言中,要求对所有用到的变量做强制定义,简单说就是“先定义,后使用”。目的:1、凡未被事先定义的,系统不把它认作变量名,这就保证程序中变量名使用正确。int student;studengt=30;2、定义变量时说明了数据类型,在编译时就能为其分配 相应的存储单元。3、指定每一个变量属于一个类型,便于在编译时据此检查在程序中要求对该变量进行运算是否合法。a%b/*求余运算*/数据类型 常量与变量#define PRICE 30main( ) int num,total; float v ,r,h; num=10; total=num*PRICE; printf(total=%d,tatal); r=2.5; h=3.2; v=3.14159*r*r*h; printf(v=%fn,v);3.3 整型数据一、 整型常量 整型常量即整常数,在语言中可用三种形式表示,并且各种数制均可有正(+)负(-)之分,正数的“+”可省略。 (1)十进制:以数字19开头,其他位以数字09构成十进制整型常量。如12,-38等。(2)八进制:以数字0开头,其他位以数字07构成八进制整型常。如012,-037等。 (3)十六进制:以0X或0x开头(数字0和大写或小写字母x),其他位以数字09或字母af或AF构成十六进制整型常量。如0x12,-0Xa9等。 二、 整型变量1.分类 根据占用内存字节数的不同,整型变量又分为类:(1)基本整型(类型关键字为int)。(2)短整型(类型关键字为short int)。(3)长整型(类型关键字为long int)。(4)无符号整型。无符号型又分为无符号基本整型(unsigned int)、无符号短整型(unsigned short)和无符号长整型(unsigned long)三种,只能用来存储无符号整数。归纳起来,可以用以下6种整型变量。即: 有符号基本整型 signed int 无符号基本整型 unsigned int 有符号短整型 signed short int 无符号短整型 unsigned short int 有符号长整型 signed long int 无符号长整型 unsigned long int如果不指定unsigned或指定signed,则存储单元中最高位代表符号(0为正,1为负)。如果指定unsigned,为无符号型,存储单元中全部二进位(bit)用作存放数本身,而不包括符号。无符号型变量只能存放不带符号的整数,如123、4687等,而不能存放负数,如-123、-3。一个无符号整型变量中可以存放的正数的范围比一般整型变量中正数的范围扩大一倍。如果在程序中定义a和b两个变量:int a;unsigned int b;变量a的数值范围为-3276832767。变量b的数值范围为065535。2.占用内存字节数与值域 如果定义了一个整型变量i: int i; /* 定义为整型变量 */ i=10; /* 给i赋以整数10 */ 十进制数10的二进制形式为1010,如果使用的c编译系统,每一个整型变量在内存中占2个字节。图 (a)是数据存放的示意图。图 (b)是数据在内存中实际存放的情况。实际上,数值是以补码(complement) 表示的。一个正数的补码和其原码的形式相同。图b) 就是用补码形式表示的。求负数的补码将该数的绝对值的二进制形式,按位取反再加1。例如求-10的补码:取-10的绝对值10;10的绝对值的二进制形式为1010;对1010取反得1111111111110101(一个整数占16位);再加1得1111111111110110。 上述各类型整型变量占用的内存字节数,随系统而异。在16位操作系统中,一般用字节表示一个int型变量,且long型(字节)int型(字节)short型(字节)。显然,不同类型的整型变量,其值域不同。有符号整型变量,其值域为:-2n*8-1(2n*8-1-1);无符号整型变量,其值域为:0(2n*8-1)。(n为占用内存字节数)数据类型 整型数据的定义及取值范围 类型 定义符 位数 数值范围 I/O格式符 基本 int 16位 -3276832767 %d 短整 short 16 同上 %hd 长整 long 32 -231(231-1) %ld 无符号 unsigned int 16 065535 %u unsigned short 16 同上 %hu unsigned long 32 0(232-1) %lu例:整型变量的定义与使用。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可以看到不同种类的整型数据可以进行算术运算。在本例中是int型数据与unsigned int型数据进行相加相减运算(有关运算的规则在本章3.7节中介绍)。4. 整型数据的溢出在turbo c中一个int型变量的最大允许值为32767,如果再加1,会出现什么情况?例:整型数据的溢出。main()int a,b;a=32767; b=a+1;printf(%d,%d,a,b);运行结果为32767,-32768三、整型常量的类型 整型变量可分为:intunsigned intshort intunsigned shortlong intunsigned long 常量是否也有这些类别? 在将一个整型常量赋值给上述几种类别的整型变量时如何做到类型匹配?请注意以下几点:(1) 一个整数,如果其值在-32768+32767范围内,认为它是int型,它可以赋值给int型和long int型变量。(2) 一个整数,如果其值超过了上述范围,而在-2147483648+2147483647范围内,则认为它是长整型,可以将它赋值给一个long int型变量。(3) 如果某一计算机系统的c版本(例如turbo c)确定short int与int型数 据在内存中占据的长度相同,则它的表数范围与int型相同。因此,一个int型的常量也同时是一个short int型常量,可以赋给int型或short int型变量。(4) 一个整常量后面加一个字母u,认为是unsigned int型,如12345u,在内存中按unsigned int规定的方式存放(存储单元中最高位不作为符号位,而用来存储数据,见图3.4(b)。如果写成-12345u,则先将-12345转换成其补码53191,然后按无符号数存储。(5) 在一个整常量后面加一个字母l或l,则认为是long int型常量。例如123l、432l、0l等,这往往用于函数调用中。如果函数的形参为long int型,则要求实参也为long int型,此时用123作实参不行,而要用123l作实参。数据类型 整型数据#define PRICE 30main( ) int num,total; float v ,r,h; num=10; total=num*PRICE; printf(total=%d,tatal); r=2.5; h=3.2; v=3.14159*r*r*h; printf(v=%fn,v); 3.4 实型数据(浮点型数据)一、 实型常量.表示形式实型常量即实数,在语言中又称浮点数,其值有两种表达形式:(1)十进制形式。例如3.14、9.8、0.135。 (2)指数形式:E(e)。例如3.0+5等。 字母e之前必须有数字,e后面的指数必须为整数.如:e3.2 , 1e3.5 ,e3 ,e都是错误的。 一个实数可以有多种指数表示形式。123.456可以表示为:123.456e012.3456e11.23456e20.123456e30.0123456e40.00123456e5把其中的1.23456e2称为“规范化的指数形式”。规范化的指数形式:字母e(或e)之前的小数部分中,小数点左边应有一位(且只能有一位)非零的数字。例如2.3478e2、 3.0999e5、 6.46832e12都属于规范化的指数形式,而12.908e10、 0.4578e3、 756e0则不属于规范化的指数形式。一个实数在用指数形式输出时,是按规范化的指数形式输出的。例如,指定将实数5689.65按指数形式输出,必然输出5.68965e+003, 而不会是0.568965e+004或56.8965e+002。.关于类型 C编译系统将实型常量作为双精度型来处理(一般占个字节、提供1516位有效数字)。二、实型变量 语言的实型变量,分为两种: (1)单精度型。类型关键字为float,一般占字节(位)、提供位有效数字。 (2)双精度型。类型关键字为double,一般占个字节、提供1516位有效数字。main( ) float a,b; /* 定义为实型变量 */a=123456.789e5; /* 给实型变量a赋值*/b=a+20; /* 给实型变量b赋值*/printf(“%f”,b); /*“%f”是输出一个实数时的格式符*/ /*以十进制小数输出数值*/三、实型数据在内存中的存放形式 在常用的微机系统中,一个实型数据在内存中占4个字节(32位)。与整型数据的存储方式不同,实型数据是按照指数形式存储的。系统把一个实型数据分成小数部分和指数部分,分别存放。指数部分采用规范化的指数形式。实数 3.14159 在内存中的存放形式可以用下图示意。 图中是用十进制数来示意的,实际上在计算机中是用二进制数来表示小数部分以及用2的幂次来表示指数部分的。四. 实型数据的舍入误差在4个字节(32位)中,究竟用多少位来表示小数部分,多少位来表示指数部分?标准C并无具体规定,由各C编译系统自定。不少c编译系统以24位表示小数部分(包括符号),以8位表示指数部分(包括指数的符号)。小数部分占的位(bit)数愈多,数的有效数字愈多,精度愈高。指数部分占的位数愈多,则能表示的数值范围愈大。由于实型变量是由有限的存储单元组成的,因此能提供的有效数字总是有限的,在有效位以外的数字将被舍去。由此可能会产生一些误差。请分析下面的程序:例3.4实型数据的舍入误差。main( ) float a,b; /* 定义为实型变量 */a=123456.789e5; /* 给实型变量a赋值*/b=a+20; /* 给实型变量b赋值*/printf(“%f”,b); /*“%f”是输出一个实数时的格式符*/*以十进制小数输出数值*/运行结果:12345678848.000000 理论结果:12345678900+20=12345678920原因是:a的值比20大很多,a+20的理论值应是12345678920,而一个实型变量只能保证的有效数字是7位有效数字,后面的数字是无意义的,并不准确地表示该数。应当避免将一个很大的数和一个很小的数直接相加或相减,否则就会“丢失”小的数。与此类似,用程序计算1.0/3*3的结果并不等于1。数据类型 实型数据#define PRICE 30main( ) int num,total; float v ,r,h; num=10; total=num*PRICE; printf(total=%d,tatal); r=2.5; h=3.2; v=3.14159*r*r*h; printf(v=%fn,v); 3.5 字符型数据一、字符常量1.字符常量的定义用一对单引号括起来的单个字符,称为字符常量。例如,A、等。单引号只是字符与其它部分的分隔符,不是字符的一部分,输出该字符常量时,不显示单引号。2.转义字符语言还允许使用一种特殊形式的字符常量,就是以反斜杠“ ”开头的转义字符。(P48 表3.3)例如,前面已经遇到过的,在printf函数中的n,它代表一个“换行”符。这是一种“控制字符”,在屏幕上是不能显示的。 注意:单引号中的字符不能是单引号或反斜杠,如: 或 ,如果反斜杠或单引号本身作为字符常量,必须使用转义字符:、。例3.5转义字符的使用。main()printf(abctderftgn);printf(htibbj k);t:水平制表符(跳到下一个tab位置)r:回车,将当前位置移动到本行开头n:换行,将当前位置移到下一行的开头b:退格,将当前位置移到前一列运行结果:fgdehjk二、字符变量字符变量的类型关键字为char,一般占用1字节内存单元。1.变量值的存储 字符变量用来存储字符常量。将一个字符常量存储到一个字符变量中,实际上是将该字符的ASCII码值(无符号整数)存储到内存单元中。例如: char ch1; /*定义一个字符变量:ch1*/ ch1=a; /*给字符变量赋值*/因a的ASCII码为97,则在内存中的存储形式为01100001,如同存放整数97。例:main( ) char ch; 运行结果为97 ch=a 可见:字符数据等价于其对应的 printf(“%d”,ch); ASCII码 2.特性 字符数据在内存中存储的是字符的ASCII码 一个无符号整数,其形式与整数的存储形式一样,所以语言允许字符型数据与整型数据之间通用。(1)一个字符型数据,既可以字符形式输出,也可以整数形式输出。 例 字符变量的字符形式输出和整数形式输出。 /*程序功能:用字符形式和整数形式输出字符变量*/ main( ) char ch1,ch2; ch1=a; ch2=b; printf(“ch1=%c,ch2=%cn”,ch1,ch2); printf(“ch1=%d,ch2=%dn”,ch1,ch2); 程序运行结果: ch1=a,ch2=b ch1=97,ch2=98(2)允许对字符数据进行算术运算,此时就是对它们的ASCII码值进行算术运算。 例3.2 字符数据的算术运算。 /*例题代码文件名:LT3_2C*/ /*程序功能:字符数据的算术运算*/ main( ) char ch1,ch2; ch1=a; ch2=B; /*字母的大小写转换*/ printf(“ch1=%c,ch2=%cn”,ch1-32,ch2+32); /*用字符形式输出一个大于256的数值*/ printf(ch1+200=%dn, ch1+200); printf(ch1+200=%cn, ch1+200); printf(ch1+256=%dn, ch1+256); printf(ch1+256=%cn, ch1+256); 程序运行结果: ch1=A,ch2=b ch1+200=297 ch1+200=) ch1+256=353 ch1+256=a 思考题:用字符形式输出一个大于256的数值,会得到什么结果?三、 字符串常量1.字符串常量的概念和字符串长度字符串常量是用一对双引号括起来的若干字符序列。字符串中字符的个数称为字符串长度。长度为0的字符串(即一个字符都没有的字符串)称为空串,表示为“ ” (一对紧连的双引号)。例如,“How do you do.”、“Good morning.”等,都是字符串常量,其长度分别为14和13(空格也是一个字符)。 如果反斜杠和双引号作为字符串中的有效字符,则必须使用转义字符。例如:(1)C:msdosv6.22 “C:msdosv6.22” (2)I say:Goodbye! “I say:Goodbye!”2.字符串的存储 C语言规定:在存储字符串常量时,由系统在字符串的末尾自动加一个0作为字符串的结束标志。 注意:在源程序中书写字符串常量时,不必加结束字符0,否则画蛇添足。 如果有一个字符串为“CHINA”,则它在内存中的实际存储如下所示: 最后一个字符0是系统自动加上的,它占用字节而非字节内存空间。综上所述,字符常量A与字符串常量A是两回事:(1)定界符不同:字符常量使用单引号,而字符串常量使用双引号;(2)长度不同:字符常量的长度固定为1,而字符串常量的长度,可以是0,也可以是某个整数;(3)存储要求不同:字符常量存储的是字符的ASCII码值,而字符串常量,除了要存储有效的字符外,还要存储一个结束标志0。3.6 变量赋初值1. 先定义后赋值 如: int a,b,c; a=3; b=-6 ; c=34;2. 定义的同时赋初值 如: int a=3; float b=3.56; char c=a ; 如果a,b,c初值相等,只能写成:int a=3,b=3,c=3;不能写成int a=b=c=3;3.7 各类数值型数据间的混合运算 在语言中,整型、实型和字符型数据间可以混合运算。 (因为字符数据与整型数据可以通用)。 如果一个运算符两侧的操作数的数据类型不同,则系统按“先转换、后运算”的原则,首先将数据自动转换成同一类型,然后在同一类型数据间进行运算。转换规则如图所示。 高 doublefloat long unsigned 低 intchar、short转换规则(系统自动转换): 高 doublefloat long unsigned 低 intchar、short1)横向向左的箭头,表示必须的转换。char和short 型必须转换成 int 型,float型必须转换成double型。 2)纵向向上的箭头,表示不同类型的转换方向。 例如,int型与double型数据进行混合运算,则先将int型数据转换成double型,然后在两个同类型的数据间进行运算,结果为double型。 注意:箭头方向只表示数据类型由低向高转换,不要理解为int型先转换成unsigned型,再转换成long型,最后转换成double型。例1: int i; float f; double d; long L; 10 + a + i * f - d / Lint char int float double long int double double double double两个float型数值作运算也是先转为double型再作运算3.8 算术运算与算术表达式在语言中,除控制语句和输入输出函数外,其它所有基本操作都作为运算符处理。1.五种基本算术运算符 + 、-(减法/取负)、*、/、%(求余数)(1)关于除法运算/C语言规定:两个整数相除,其商为整数,小数部分被舍弃。例如,5 / 2 = 2。两个实数相除,则结果为实型, 1.5 /2=0.75。 (2)关于求余数运算要求两侧的操作数均为整型数据,否则出错。2.表达式和算术表达式(1)表达式的概念 用运算符和括号将运算对象(常量、变量和函数等)连接起来的、符合语言语法规则的式子,称为表达式。单个常量、变量或函数,可以看作是表达式的一种特例。将单个常量、变量或函数构成的表达式称为简单表达式,其它表达式称之为复杂表达式。(2)算术表达式的概念表达式中的运算符都是算术运算符。例如,3 + 6 * 9、(x + y) / 2 - 1等,都是算术表达式。良好的源程序书写习惯:在表达式中,在双目运算符的左右两侧各加一个空格,可增强程序的可读性。请比较表达式“ (x + y) / 2 1”与“(x+y)/21”,您认为哪个的可读性更好一些?3.运算符的优先级与结合性(1)语言规定了运算符的优先级和结合性。 所谓结合性是指,当一个操作数两侧的运算符具有相同的优先级时,该操作数是先与左边的运算符结合,还是先与右边的运算符结合。自左至右的结合方向,称为左结合性。反之,称为右结合性。结合性是语言的独有概念。除单目运算符、赋值运算符和条件运算符是右结合性外,其它运算符都是左结合性。(2)表达式求值1)按运算符的优先级高低次序执行。例如,先乘除后加减。2)如果在一个运算对象(或称操作数)两侧的运算符的优先级相同,则按语言规定的结合方向(结合性)进行。例如,算术运算符的结合方向是“自左至右”,即:在执行“a b + c”时,变量b先与减号结合,执行“a - b”;然后再执行加c的运算。4.数据类型转换在语言中,不同数据类型系统除可自动转换外,也允许强制转换。数据类型强制转换的一般格式为: (要转换成的数据类型)(被转换的表达式)当被转换的表达式是一个简单表达式时,外面的一对圆括号可以缺省。例如:(double)a (等价于(double)(a) /*将变量a的值转换成double型*/(int)(x + y) /*将x+y的结果转换成int型*/(float)5 / 2 (等价于(float)(5)/2) /*将5转换成实型,再除以2(=2.5)*/(float)(5 / 2) /*将5整除2的结果(2)转换成实型(2.0)*/注意:强制转换类型得到的是一个所需类型的中间变量,并不改变原变量类型 。例如,(double)a 只是将变量a的值转换成一个double型的中间量,其数据类型并未转换成double型。例题: main( ) float x; int i; x=3.6; i=(int)x; printf(x=%f,i=%dn,x,i); 运行结果:x=3.600000, i=3 5. C语言特有的运算和运算符自增(+)、自减(-)运算 1.作用自增运算使单个变量的值增,自减运算使单个变量的值减。 2.用法与运算规则自增、自减运算符都有两种用法:(1)前置运算运算符放在变量之前:变量、变量 先使变量的值增(或减),然后再以变化后的值参与其它运算,即先增减、后运算。 例:int I = 5 ; x = + + I ; I = I+1; x = I; y = I ;(2)后置运算运算符放在变量之后:变量、变量 变量先参与其它运算,然后再使变量的值增(或减),即先运算、后增减。 例: int I=5 ; x = I+ ; x=I ; I= I+1; y = I;例3.3 自增、自减运算符的用法与运算规则示例。 /*例题代码文件名:LT3_3.C*/ /*程序功能:自增、自减运算符的用法与运算规则示例*/ main( ) int x=6 , y; printf(x=%dn,x); /*输出x的初值*/ y = + + x ; /*前置运算*/ printf(y=+x: x=%d,y=%dn,x,y); y = x- - ; /*后置运算*/ printf(y=x-: x=%d,y=%dn,x,y); 程序运行结果: x=6 y= +x: x=7,y=7 y= x-: x=6,y=7 思考题:如果将例题“y=+x;”语句中的前置运算改为后置(y=x+ ;),“y=x- -;”语句中的后置运算改为前置(y=-x;),程序运行结果会如何?3.说明(1)自增、自减运算,常用于循环语句中,使循环控制变量加(或减),以及指针变量中,使指针指向下(或上)一个地址。(2)自增、自减运算符,不能用于常量和表达式。例如,5+、- -(a+b)等都是非法的。(3)+和- -运算符的结合方向是:“自右向左”。(4)在表达式中,连续使同一变量进行自增或自减运算时,很容易出错,所以最好避免这种用法。两个例题略3.9 赋值运算与赋值表达式1.赋值运算赋值符号“=”就是赋值运算符,非等号。它的作用是将一个表达式的值赋给一个变量。赋值运算符的一般形式为: 变量 = 赋值表达式 例如,x = 5 y = (float)5 / 2 如果表达式值的类型与被赋值变量的类型不一致,但都是数值型或字符型时,系统自动地将表达式的值转换成被赋值变量的数据类型,然后再赋值给变量。 思考题:假设变量num的数据类型为float,其值为2.5,则执行“num = (int)num”后,num的值等于多少?例题:include main( ) unsigned a; int b=-1; a=b; printf(%un,a);运行结果655352.复合赋值运算复合赋值运算符是由赋值运算符之前再加一个双目运算符构成的。复合赋值运算的一般格式为: 变量 双目运算符 = 表达式 复合赋值运算符它等价于:变量 = 变量 双目运算符 (表达式)。当表达式为简单表达式时,表达式外的一对圆括号才可缺省,否则可能出错。例如,x + = 3 /* 等价于x=x+3 */ y * = x + 6 /* 等价于y=y*(x+6),而不是y=y*x+6 */C语言规定的10种复合赋值运算符如下:+=,-=,*=,/=,%=; /*复合算术运算符(5个)*/&=,=,|=,=;/*复合位运算符(5个)*/3.赋值表达式由赋值运算符或复合赋值运算符,将一个变量和一个表达式连接起来的表达式,称为赋值表达式。(1)一般格式 变量 (复合)赋值运算符 表达式(2)赋值表达式的值任何一个表达式都有一个值,赋值表达式也不例外。
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- JJF(石化)059-2023环氧乙烷气体检测报警器校准规范
- 2025新版部编人教版小学三年级数学上册全册教案
- 重庆直播红娘培训课件
- 暑假新课专项重点预习练:解答题(含解析)-2024-2025学年人教版一年级数学下学期
- 人教版八年级英语上册Unit7达标测试卷(含答案)
- 新解读《GB-T 5671-2014汽车通 用锂基润滑脂》
- 人教版Unit 3 Same or Different Section B -2025年新八年级英语暑期提升讲义(含答案)
- 重大手术知识培训课件
- 高空作业车、汽车起重机风险识别与安全使用管控要点
- 老年人讲文明课件
- 2025-2026学年人教版(2024)小学数学三年级上册(全册)教学设计(附目录P296)
- 碳中和技术概论全套教学课件
- 材料风险调差表
- 压力容器材料
- 招标投标法9个课件
- 100个最具争议的涉税经典稽查案例深度解析1增值税退税
- 高等数学上册ppt课件完整版
- 网店美工与视觉设计全书ppt完整版课件最全电子教案正本书教学教程
- 胸部检查(二)肺与胸膜检查
- 《中国古典舞》PPT课件
- 小学生个人简历WORD模板
评论
0/150
提交评论