版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、数据类型决定:数据类型决定:1. 数据占内存字节数数据占内存字节数2. 数据取值范围数据取值范围3. 其上可进行的操作其上可进行的操作2.2.1 常量和符号常量常量和符号常量在程序运行过程中在程序运行过程中, ,其值不能被改变的量称为常量其值不能被改变的量称为常量常量区分为不同的类型:常量区分为不同的类型:整型整型 100100,125125,-100-100,0 0实型实型 3.14 3.14 , 0.1250.125,-3.789-3.789字符型字符型 a, ba, b,22字符串字符串 “a”, “a”, “a ab b”,”1232”1232” 程序中用#define命令行定义PI代
2、表常量3.14,此后凡在本文件中出现的PI都代表3.14,可以和常量一样进行运算用一个标识符代表一个常量的,称为符号常量,即以标识符形式出现的常量。符号常量的值在其作用域(在本例中为主函数)内不能改变,也不能再被赋值。 如再用赋值语句给PI赋值是错误的。Pi=4;/* 错误,不能给符号常量赋值*/3.2.23.2.2变量变量 变量代表内存中具有特定属性的一个存储变量代表内存中具有特定属性的一个存储单元,它用来存放数据,这就是变量的值,在单元,它用来存放数据,这就是变量的值,在程序运行期间,这些值是可以改变的。程序运行期间,这些值是可以改变的。 变量名实际上是一个以一个名字对应代表变量名实际上是
3、一个以一个名字对应代表一个地址,在对程序编译连接时由编译系统给一个地址,在对程序编译连接时由编译系统给每一个变量名分配对应的内存地址。从变量中每一个变量名分配对应的内存地址。从变量中取值,实际上是通过变量名找到相应的内存地取值,实际上是通过变量名找到相应的内存地址,从该存储单元中读取数据。址,从该存储单元中读取数据。 变量命名的规定:变量命名的规定: 语言规定标识符只能由字母、数字和下划线三种字符组成,且第一个字符必须为字母或下划线。 例:例:sum,_total, month, Student_name lotus_1_2_,BASIC, li_ling M.D.John, ¥123,3D6
4、4,ab 编译系统将编译系统将大写字母和小写字母认为大写字母和小写字母认为是两个是两个不同的字符。不同的字符。 建议变量名的长度最好不要超过建议变量名的长度最好不要超过8 8个字符。个字符。在选择变量名和其它标识符时,应注意做到在选择变量名和其它标识符时,应注意做到“见名知意见名知意”,即选有含意的英文单词即选有含意的英文单词 (或其缩写)作标识符。(或其缩写)作标识符。要求对所有用到的变量作强制定义,也就是要求对所有用到的变量作强制定义,也就是“先定义,后使用先定义,后使用” 。注意注意2.3.1整型常量的表示方法整型常量的表示方法 整型常量即整常数。在语言中,整常数可用以下三种形式表示:(
5、1)十进制整数。 如:如:123, -456.4。(2)八进制整数。以0头的数是八进制数。 如:如:0123表示八进制数123,等于十进制数83,-011表示八进制数-11,即十进制数-9。(3)(3)十六进制整数。以十六进制整数。以0 x0 x开头的数是开头的数是1616进制数。进制数。 如:如:0 x1230 x123,代表,代表1616进制数进制数123,123,等于十进制数等于十进制数291 291 .zzzz .zzzz-0 x12-0 x12等于十等于十进制数进制数1010 2.3.2 整型变量整型变量 (1)整型数据在内存中的存放形式 数据在内存中是以二进制形式存放的。 如: i
6、nt i; /* 定义为整型变量 */ i=10; /* 给i赋以整数10 */ 十进制数10的二进制形式为1010,Turbo C 2.0和Turbo C+ 3.0为一个整型变量在内存中分配2个字节的存储单元(不同的编译系统为整型数据分配的字节数是不相同的,VC+ 6.0则分配4个字节)。数值是以补码(complement) 表示的。 (2)(2)整型变量的分类:整型变量的分类:共共六六种种有符号基本整型有符号短整型有符号长整型无符号基本整型无符号短整型无符号长整型(signed)int (signed)short (int )(signed) long (int)unsigned intu
7、nsigned short (int)unsigned long (int)括号表示其中的内容是可选的括号表示其中的内容是可选的注意注意整数类型的有关数据:(3)3)整型变量的定义整型变量的定义: : 规定在程序中所有用到的变量都必须在规定在程序中所有用到的变量都必须在程序中定义,即程序中定义,即“强制类型定义强制类型定义”。 例如例如: : intint a,b a,b(指定变量、为整型)(指定变量、为整型) unsigned short c,d;unsigned short c,d;(指定变量、(指定变量、为无符号短整型)为无符号短整型) long e,f;long e,f;( (指定变量
8、、为长整型)指定变量、为长整型)可以看到不同种类的整型数据可以进行算术运算 运行结果运行结果: :, 2.3.3 整型常量的类型整型常量的类型 (1)一个整数,如果其值在-32768+32767范围内,认为它是short int型,它可以赋值给short int型变量。 (2) 一个整数,如果其值超过了上述范围,而在-2147483637+2147483647(-231 231-1)范围内,则认为它是基本整型为长整型。可以将它赋值给一个int或long int型变量。 (3) 一个整常量后面加一个字母u或U,认为是unsigned int型,如12345u,在内存中按unsigned int规
9、定的方式存放(存储单元中最高位不作为符号位,而用来存储数据)。如果写成-12345u,则先将-12345转换成其补码53191,然后按无符号数存储。(4) 在一个整常量后面加一个字母l或L,则认为是long int型常量。例如123l.432L.0L等。这往往用于函数调用中。如果函数的形参为long int型,则要求实参也为long int型。2.4.12.4.1浮点型常量的表示方法浮点型常量的表示方法两种表两种表示形式示形式小数小数指数指数0.1230.1233e-33e-3 字母字母e(e(或或E)E)之前必须有数字,且之前必须有数字,且e e后面的指后面的指数必须为整数数必须为整数 X
10、X 注意注意规范化的指数形式:规范化的指数形式: 在字母e(或E)之前的小数部分中,小数点左边应有一位(且只能有一位)非零的数字. 例如例如: : 123.456可以表示为: 123.456e0, 12.3456e1, 1.23456e2, 0.123456e3, 0.0123456e4, 0.00123456e 其中的1.23456e31.23456e3称为“规范化的指数形式”。2.4.2 2.4.2 浮点型变量浮点型变量(1)(1)浮点型数据在内存中的存放形式浮点型数据在内存中的存放形式 一个浮点型数据一般在内存中占一个浮点型数据一般在内存中占4 4个字个字节节(32(32位位) )。与整
11、型数据的存储方式不同,浮。与整型数据的存储方式不同,浮点型数据是按照指数形式存储的。系统把一点型数据是按照指数形式存储的。系统把一个浮点型数据分成小数部分和指数部分,分个浮点型数据分成小数部分和指数部分,分别存放。指数部分采用规范化的指数形式别存放。指数部分采用规范化的指数形式。类型类型 位数位数 数的范围数的范围 有效数有效数字字float float 32 32 1010-37 -37 101038 38 6 67 7 位位doubledouble型型 64 64 1010-307-3071010308308 15 151616位位long double 128 10long double
12、 128 10-4931-493110104932 4932 18181919位位(2) (2) 浮点型变量的分类浮点型变量的分类 浮点型变量分为单精度(float型)、双精度(double型)和长双精度型(long double)三类形式。一个浮点型变量只能保证的有效数字是7位有效数字,后面的数字是无意义的,并不准确地表示该数。应当避免将一个很大的数和一个很小的数直接相加或相减,否则就会“丢失”小的数运行结果:运行结果: 123456.789e5123456.789e52.4.3 浮点型常量的类型浮点型常量的类型 C C编译系统将浮点型常量作为双精度来处理编译系统将浮点型常量作为双精度来处理
13、 例如例如:f = 2.45678 f = 2.45678 * * 4523.65 4523.65 系统先把系统先把2.456782.45678和和4523.654523.65作为双精度数,然作为双精度数,然后进行相乘的运算,得到的乘也是一个双精度数。后进行相乘的运算,得到的乘也是一个双精度数。最后取其前最后取其前7 7位赋给浮点型变量位赋给浮点型变量f f。2.5.1 字符常量字符常量(1)(1)用单引号包含的一个字符是字符型常量用单引号包含的一个字符是字符型常量(2)(2)只能包含一个字符只能包含一个字符a,A, 1a,A, 1abcabc、“a”a”注意注意 有些以有些以“”开头的特殊字
14、符称为转义字符开头的特殊字符称为转义字符n n 换行换行t t 横横向跳格向跳格r r 回回车车 反反斜杠斜杠dddddd dddddd表示表示1 1到到3 3位八进制数字位八进制数字xhhxhh hhhh表示表示1 1到到2 2位十六进制数字位十六进制数字如 101 -A 012 -n 376 - x61 -a 60 -0 483 -()例:A-101-x41-65如 A65, a97, 048 , n10如 a A ? n 101例例 转义字符举例转义字符举例(ch2_001.c,ch2_004.c) main() printf(101 x42 Cn); printf(I say:How
15、are you?n); printf(C Programn); printf(Turbo C);运行结果:运行结果:(屏幕显示屏幕显示)A B CIsay:”How are you?”C ProgramTurbo C例例 main() printf(“Yb=n”); 运行结果:运行结果:屏幕显示:屏幕显示:=打印机输出:打印机输出:2.5.2字符变量字符变量字符型变量用来存放字符常量,注意只能放一字符型变量用来存放字符常量,注意只能放一个字符。个字符。字符变量的定义形式如下:字符变量的定义形式如下:char c1,c2;char c1,c2;在本函数中可以用下面语句对在本函数中可以用下面语句对
16、c1,c2c1,c2赋值:赋值: c1c1aa;c2c2 b b ;一个字符变量在内存中占一个字节。一个字符变量在内存中占一个字节。 2.5.3字符数据在内存中的存储形式及其使用方法字符数据在内存中的存储形式及其使用方法将一个字符常量放到一个字符变量中,实际上并不将一个字符常量放到一个字符变量中,实际上并不是把该字符本身放到内存单元中去,而是将该字符是把该字符本身放到内存单元中去,而是将该字符的相应的的相应的ASCIIASCII代码放到存储单元中。代码放到存储单元中。这样使字符型数据和整型数据这样使字符型数据和整型数据之间可以通用。一个字符数据之间可以通用。一个字符数据既可以以字符形式输出,也
17、可既可以以字符形式输出,也可以以整数形式输出。以以整数形式输出。注意注意在第和第4行中,将整数和分别赋给c1和c2,它的作用相当于以下两个赋值语句:c1;c2;因为a和b的ASCII码为和运行结果:运行结果: 97 9897 98程序的作用是将两个小写字母a和b转换成大写字母A和B。从代码表中可以看到每一个小写字母比它相应的大写字母的码大。语言允许字符数据与整数直接进行算术运算。 运行结果:运行结果: 2.5.4字符串常量字符串常量字符串常量字符串常量是一对是一对双撇号双撇号括起来的字符序列括起来的字符序列. .合法的字符串常量合法的字符串常量: :“How do you do.”, “CHI
18、NA”How do you do.”, “CHINA”, “a” a” , “ “$123.45”$123.45”可以输出一个字符串,如可以输出一个字符串,如printf(“Howprintf(“How do you do.”) do you do.”); 是字符常量,是字符常量, ” ”是字符串常量,二者不同。是字符串常量,二者不同。 如如:假设被指定为字符变量:假设被指定为字符变量 :char c;char c;c=a;c=a; ”a”a”;c c”CHINA”;CHINA”; 结论结论:不能把一个字符串常量赋给一个字符变量。规定:在每一个字符串常量的结尾加一个规定:在每一个字符串常量的结
19、尾加一个 “ “字符字符串结束标志串结束标志”,以便系统据此判断字符串是否结束。,以便系统据此判断字符串是否结束。规定以字符规定以字符作为字符串结束标志。作为字符串结束标志。 如如:如果有一个字符串常量如果有一个字符串常量” ” ,实,实际上在内存中是:际上在内存中是: 它占内存单元不是个字符,而是个字符,它占内存单元不是个字符,而是个字符,最后一个字符为最后一个字符为。但在输出时不输出。但在输出时不输出。(1)语言允许在定义变量的同时使变量初始化如如: : int a=3; / 指定为整型变量,初值为 float f=3.56; / 指定为浮点型变量,初值为.56 char c= a; /
20、指定为字符变量,初值为a (2)可以使被定义的变量的一部分赋初值。 如如: : int a,b,c=5; 表示指定、为整型变量,但只对初始化,c的初值为(3)如果对几个变量赋以同一个初值, 应写成:int a=3,b=3,c=3; 表示、的初值都是。 不能写成 int a=b=c=3; 注意:注意:初始化不是在编译阶段完成的而是在程序运行时执行本函数时赋初值的,相当于有一个赋值语句。 整型(包括int,short,long)、浮点型(包括float,double)可以混合运算。在进行运算时,不同类型的数据要先转换成同一类型,然后进行运算.不同类型数据间的转换隐式转换运算转换-不同类型数据混合运
21、算时赋值转换-把一个值赋给与其类型不同的变量时输出转换-输出时转换成指定的输出格式函数调用转换-实参与形参类型不一致时转换运算转换规则:不同类型数据运算时先自动转换成同一类型doublefloatlongunsignedintchar,short低高说明:必定的转换运算对象类型不同时转换例 char ch; int i; float f; double d;ch/i + f*d - (f+i)intintdoubledoubledoubledoubledoubledoubleintintdoubledoubledoubledoubledoubledouble10+a +i*f - d/l例 i
22、nt i; float f; double d; long l;3.8.1 3.8.1 运算符简介运算符简介 的运算符有以下几类:的运算符有以下几类:(1)算术运算符 (+ - * / %)(2)关系运算符 (!)(3)逻辑运算符 (!|)(4)位运算符 ( |)(5)赋值运算符 (及其扩展赋值运算符)(6)条件运算符 (?:)(7)逗号运算符 (,)(8)指针运算符 (*和)(9)求字节数运算符()(10)强制类型转换运算符( (类型) )(11)分量运算符(-)(12)下标运算符()(13)其他 (如函数调用运算符()3.8.2 算术运算符和算术表达式算术运算符和算术表达式 (1)(1)基
23、本的算术运算符基本的算术运算符: : (加法运算符,或正值运算符。如(加法运算符,或正值运算符。如: :、)、) (减法运算符,或负值运算符。如(减法运算符,或负值运算符。如: :、)、)* * (乘法运算符。如(乘法运算符。如: :* *) (除法运算符。如(除法运算符。如: :) (模运算符,或称求余运算符(模运算符,或称求余运算符,两侧均应为整,两侧均应为整型数据型数据,如,如: :的值为的值为; ;5%35%3的值为的值为2 2;- -5%35%3的值为的值为-2-2; 5%(-3)5%(-3)的值为的值为2 2;-5%(-3)-5%(-3)的值为的值为-2-2;12.3%3 12.3
24、%3 若若a a能被能被b b整除,则有:整除,则有:a%b=0 a%b=0 )。)。(2) (2) 算术表达式和运算符的优先级与结合性算术表达式和运算符的优先级与结合性基本的算术运算符基本的算术运算符: : 用算术运算符和括号将运算对象用算术运算符和括号将运算对象( (也称操作数)也称操作数)连接起来的、符合语法规则的式子,称为连接起来的、符合语法规则的式子,称为算术表达式。运算对象包括常量、变量、算术表达式。运算对象包括常量、变量、函数等。函数等。 例如例如: : * */ /- -.5.5aa是一个合法的表达是一个合法的表达式式语言规定了运算符的优先级和结合性。语言规定了运算符的优先级和
25、结合性。 在表达式求值时,先按运算符的优先级别高低在表达式求值时,先按运算符的优先级别高低次序执行,例如先乘除后加减。次序执行,例如先乘除后加减。 规定了各种运算符的结合方向规定了各种运算符的结合方向( (结合性结合性) ) 算术运算符的结合方向为算术运算符的结合方向为“自左至右自左至右”,即先,即先左后右左后右 。 double float long unsigned int char,short float a=2.0;float a=2.0; int b =6,c =3; int b =6,c =3; a a* *b/c -1.5 +a b/c -1.5 +a +fabs(-5)+fab
26、s(-5)12.012.0/3/354.0 4.0 - 1.5- 1.52.52.5 + 97(int)+ 97(int)99.599.5 + 5+ 5104.5(double)104.5(double)(3)(3)强制类型转换运算符强制类型转换运算符 可以利用强制类型转换运算符将一个表达式可以利用强制类型转换运算符将一个表达式转换成所需类型。转换成所需类型。 一般形式一般形式: :(类型名)(表达式)(类型名)(表达式)例如:例如:(double)(double) 将转换成将转换成doubledouble类型类型(int)(x+y(int)(x+y) ) 将将x+yx+y的值转换成整型的值转
27、换成整型(float)(float)(5%35%3) 将将5%35%3的值转换成的值转换成floatfloat型型有两种类型转换,一种是在运算时不必用户指定,系统自动进行的类型转换,如3+6.5。第二种是强制类型转换。当自动类型转换不能实现目的时,可以用强制类型转换。运行结果:运行结果: x3.600000, i=3(4)(4) 自增、自减运算符自增、自减运算符 +i,-i+i,-i:使用之前使:使用之前使i i的值增的值增1 1(或减(或减1 1);); i+,i- i+,i-:使用之后使:使用之后使i i的值增的值增1 1(或减(或减1 1););等价于等价于 i=i+1;i=i+1;j=
28、i;i+; j=i;i+; 所以所以i i的值为的值为4 4,j j的值为的值为3 3。i+;j=i; i+;j=i; 所以所以i i的值为的值为4 4,j j的值为的值为4 4。例如:例如:(1) i+;(1) i+; +i; +i;(2) i=3;(2) i=3; j=i+; j=i+; (3) i=3;(3) i=3; j=+i; j=+i; 结合性:自右至左。结合性:自右至左。 如:如: i = 2;i = 2; j = -i+; j = -i+; 等价于等价于:j=-(i+);j=-(i+); 即:即: j=-i;i+; j=-i;i+; “+”与与”- -“是同优先级是同优先级 所
29、以所以i i的值为的值为3 3,j j的值为的值为-2-2。 注意注意 “ “+”+”或或“-”-”自增与自减运算符的使自增与自减运算符的使用。用。 如:设如:设i=3i=3,k=(i+)+(i+)+(i+)k=(i+)+(i+)+(i+),k=k=? 如:设如:设i=3i=3,j=4j=4,k=i+jk=i+j,k=k=?注意注意: (1)(1)自增运算符(),自减运算符(),自增运算符(),自减运算符(),只能用于变量,而不能用于常量或表达式,只能用于变量,而不能用于常量或表达式, (2)(2)和的结合方向是和的结合方向是“自右至左自右至左”。 自增(减)运算符常用于循环语句中使循环变量自
30、增(减)运算符常用于循环语句中使循环变量自动加。也用于指针变量,使指针指向下一个地址自动加。也用于指针变量,使指针指向下一个地址 (5) (5) 有关表达式使用中的问题说明有关表达式使用中的问题说明 ANSI CANSI C并没有具体规定表达式中的子表达式的求并没有具体规定表达式中的子表达式的求值顺序,允许各编译系统自己安排。值顺序,允许各编译系统自己安排。 例如例如:对表达式:对表达式 a = f1( )+f2( )a = f1( )+f2( ) 并不是所有的编译系统都先调用并不是所有的编译系统都先调用f1( )f1( ), 然后然后调用调用f2( )f2( )。在有的情况下结果可能不同。有
31、时会出。在有的情况下结果可能不同。有时会出现一些令人容易搞混的问题,因此务必要小心谨慎现一些令人容易搞混的问题,因此务必要小心谨慎。 语言中有的运算符为一个字符,有的运算符由语言中有的运算符为一个字符,有的运算符由两个字符组成两个字符组成 ,为避免误解,最好采取大家都能理,为避免误解,最好采取大家都能理解的写法。解的写法。 例如例如:不要写成不要写成i+ji+j的形式,而应写成的形式,而应写成 (i+)+j(i+)+j的形式的形式 在调用函数时,实参数的求值顺序,标准并无在调用函数时,实参数的求值顺序,标准并无统一规定。统一规定。 例如:的初值为,如果有下面的函数调用:例如:的初值为,如果有下
32、面的函数调用: printfprintf(,i+)i+) 在有在有的系统中,从左至右求值,输出的系统中,从左至右求值,输出“,”。在多。在多数系统中对函数参数的求值顺序是自右而左,数系统中对函数参数的求值顺序是自右而左,函数输出的是函数输出的是“,”。以上这种写法。以上这种写法不宜提倡,不宜提倡, 最好改写成最好改写成 j = i+;j = i+; printf(%d printf(%d, %d%d, j j,i)i)不要写出别人看不懂的也不知道系统会怎样执行程序(1)(1)赋值运算符赋值运算符 赋值符号赋值符号“”就是赋值运算符,它的作用是就是赋值运算符,它的作用是将一个数据赋给一个变量。如
33、将一个数据赋给一个变量。如“”的作用的作用是执行一次赋值操作(或称赋值运算)。把常是执行一次赋值操作(或称赋值运算)。把常量赋给变量。也可以将一个表达式的值赋量赋给变量。也可以将一个表达式的值赋给一个变量给一个变量. . (2) (2)类型转换类型转换 如果赋值运算符两侧的类型不一致,但都如果赋值运算符两侧的类型不一致,但都是数值型或字符型时,在赋值时要进行类型是数值型或字符型时,在赋值时要进行类型转换。转换。将浮点型数据将浮点型数据(包括单、双精度)(包括单、双精度)赋给整赋给整型变量时,舍弃浮点数的小数部分。型变量时,舍弃浮点数的小数部分。如如: :ntnt i; i;执行执行“i=3.5
34、6”i=3.56”的结果是使的结果是使的值为,以整数形式存储在整型变量中的值为,以整数形式存储在整型变量中. . 将整型数据赋给单、双精度变量时,数值不变,将整型数据赋给单、双精度变量时,数值不变,但以浮点数形式存储到变量中但以浮点数形式存储到变量中 如如: : 将赋给将赋给floatfloat变量变量f,f,即执行即执行f f23,23,先将先将2323转换成转换成23.00000,23.00000,再存储在中。再存储在中。 将将2323赋给赋给doubledouble型变量型变量d,d,即执行即执行d=23,d=23,则将则将补足有效位数字为补足有效位数字为23.0000000000000
35、0,23.00000000000000,然后然后以双精度浮点数形式存储到变量以双精度浮点数形式存储到变量d d中。中。 将一个将一个doubledouble型数据赋给型数据赋给floatfloat变量时,截取其变量时,截取其前前面面7 7位有效数字,存放到位有效数字,存放到floatfloat变量的存储单元(变量的存储单元(4 4个个字节)中。但应注意数值范围不能溢出。字节)中。但应注意数值范围不能溢出。 如如: :float f;double d=123.456789e100; f=d;float f;double d=123.456789e100; f=d; 就出现溢出的错误。如果将一个就
36、出现溢出的错误。如果将一个floatfloat型数型数据赋给据赋给doubledouble变量时,数值不变,有效位数扩变量时,数值不变,有效位数扩展到展到1616位,在内存中以位,在内存中以8 8个字节存储个字节存储字符型数据赋给整型变量时,由于字符只占字符型数据赋给整型变量时,由于字符只占1 1个字个字节,而整型变量为个字节,因此将字符数据(节,而整型变量为个字节,因此将字符数据(个二进位)放到整型变量存储单元的低位中个二进位)放到整型变量存储单元的低位中第一种情况第一种情况: :如果所用系统将字符处理为无符号的字如果所用系统将字符处理为无符号的字符类型,或程序已将字符变量定义为符类型,或程
37、序已将字符变量定义为 型,则将字符的位放到整型变量低型,则将字符的位放到整型变量低位,高位补零位,高位补零例如:例如:将字符将字符赋给型变量赋给型变量第二种情况第二种情况: : 如果所用系统(如如果所用系统(如Turbo C+Turbo C+)将字符处理为带符号)将字符处理为带符号的(即的(即signed charsigned char),若字符最高位为,则整型),若字符最高位为,则整型变量高位补;若字符最高位为,则高位全补变量高位补;若字符最高位为,则高位全补。这称为。这称为“符号扩展符号扩展”,这样做的目的是使数值保,这样做的目的是使数值保持持不变,如变量(字符不变,如变量(字符)以整数形
38、式输)以整数形式输出出为,的值也是。为,的值也是。将一个将一个intint、shortshort、longlong型数据赋给一个型数据赋给一个charchar型型变量时,只将其低变量时,只将其低8 8位原封不动地送到位原封不动地送到charchar型变量型变量(即截断)。(即截断)。例如:例如:intint i=289;char c=a;c=i; i=289;char c=a;c=i;c c的值为的值为3333, 如果用如果用“%c”%c”输出输出c c,将得到字符,将得到字符“!” !” (其(其ASCIIASCII码为码为3333)。)。 将带符号的整型数据(将带符号的整型数据(intin
39、t型)赋给型)赋给longlong型变量时,型变量时,要进行符号扩展,将整型数的要进行符号扩展,将整型数的1616位送到位送到longlong型低型低1616位中位中: :如果如果intint型数据为正值(符号位为),则型数据为正值(符号位为),则longlong型变型变量的高量的高1616位补;位补;如果如果intint型变量为负值(符号位为),则型变量为负值(符号位为),则longlong型变型变量的高量的高1616位补,以保持数值不改变。位补,以保持数值不改变。 反之,若将一个反之,若将一个longlong型数据赋给一个型数据赋给一个intint型变量,型变量,只将只将longlong型
40、数据中低型数据中低1616位原封不动地送到整型变量位原封不动地送到整型变量(即截断)。(即截断)。 将unsigned int型数据赋给long int型变量时,不存在符号扩展问题,只需将高位补即可。将一个unsigned类型数据赋给一个占字节数相同的非unsigned型整型变量(例如:unsigned int -int,unsigned long-long,unsigned short-short),将unsigned型变量的内容原样送到非unsigned型变量中,但如果数据范围超过相应整型的范围,则会出现数据错误。“%u”是输出无符号数时所用的格式符。如果为正值,且在32767之间,则赋值
41、后数值不变。运行结果:运行结果: (3) 复合的赋值运算符 *=、/=、 %=、 +=、 -=, =, &=、 =、 = 注意:复合运算符是一个运算符,但功能上,是两个运算符功能的组合。 例如: (1) a+=b 相当于 a=a+b a*=b 相当于 a=a*b a*=b+c 相当于 a=a*(b+c) 而不是a=a*b+c (2) 设a=12,计算表达式a+=a-=a*12和a+=a-=a*=12 的值(4) (4) 赋值表达式赋值表达式 由赋值运算符将一个变量和一个表达式连接起来的式子称为“赋值表达式”。一般形式为一般形式为: : 例如例如: : “5”是一个赋值表达式 对赋值表达
42、式求解的过程是:对赋值表达式求解的过程是: 求赋值运算符右侧的“表达式”的值; 赋给赋值运算符左侧的变量。例如例如: 赋值表达式“=3*5”的值为15,执行表达式后变量a的值也是15。 注意注意: 一个表达式应该有一个值一个表达式应该有一个值 左值 (value) : 赋值运算符左侧的标识符变量可以作为左值变量可以作为左值; ;而表达式就不能作为左值而表达式就不能作为左值( (如如a+b);a+b);常变量也不能作为左值。常变量也不能作为左值。 右值右值 (value)(value) : :出现在赋值运算符右侧的表达式出现在赋值运算符右侧的表达式 左值也可以出现在赋值运算符右侧,因而左值左值也可以出现在赋值运算符右侧,因而左值 都可以作为右值。都可以作为右值。 赋值表达式中的赋值表达式中的“表达式表达式”,又可以是一个赋值,又可以是一个赋值表达式表达式. .例如例如: : 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”两个赋值表达式。两个赋值表达式。 赋值运赋值
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 企业管理-彩超室管理制度
- 江苏省通州区金郊初级中学2026届初三下学期第一次统一考试(1月)物理试题含解析
- 湖北省武汉市武昌区八校2025-2026学年初三一模考试物理试题理试题含解析
- 广东汕尾甲子镇瀛江校2025-2026学年初三5月模拟(一模)考试数学试题含解析
- 珠海市紫荆中学2025-2026学年中考物理试题原创模拟卷(三)含解析
- 湖南省常德市鼎城区2026年初三第二次教学质量监测(数学试题理)试题含解析
- 车灯的日常维护与清洁
- 护理安全:防范不良事件
- 血小板减少患者的护理流程
- 审计局妇女之家活动制度
- 2025年高级(三级)中式烹调师(中式烹调)《理论知识》真题卷(答案和解析附后)
- 人工智能训练师培训课件
- 铝电解工(铝电解操作工)职业资格(技师)考试题库-上(单选题)
- 水电站大坝安全现场检查技术规程 -DL-T 2204
- 水产加工厂管理制度
- 重庆市制造业领域吸纳高校毕业生急需紧缺岗位目录(2024-2025)征
- 《食品安全监测与风险评估》课件
- 硫磺购销合同协议
- 课件:《习近平新时代中国特色社会主义思想学习纲要(2023年版)》第八章 中华人民共和国的成立与中国社会主义建设道路的探索
- 《明清中国版图的奠定与面临的挑战》单元教学设计- 近代前夜的盛世与危机
- 人员退休欢送会34
评论
0/150
提交评论