c语言程序设计谭浩强ch2基本数据类型和表达式.ppt

上传人:xin****828 文档编号:19957004 上传时间:2021-01-18 格式:PPT 页数:93 大小:1.22MB
返回 下载 相关 举报
c语言程序设计谭浩强ch2基本数据类型和表达式.ppt_第1页
第1页 / 共93页
c语言程序设计谭浩强ch2基本数据类型和表达式.ppt_第2页
第2页 / 共93页
c语言程序设计谭浩强ch2基本数据类型和表达式.ppt_第3页
第3页 / 共93页
点击查看更多>>
资源描述
第二章 本章要点 数据的描述规则 数据的操作规则 主要内容 2.1 C的数据类型 2.2 常量与变量 2.3 整型数据 2.4 浮点型数据运行 2.5 字符型数据 主要内容 2.变量赋初值 2.7 各类数值型数据间的混合运算 2.8 算术运算符和算术表达式 2.9 赋值运算符和赋值表达式 2.10 逗号运算符和逗号表达式 2021/1/18 5 数值的表示方法 原码、反码和补码 原码:最高位为符号位,其余各位为数值本身 的绝对值 反码: 正数:反码与原码相同 负数:符号位为 1,其余位对原码取反 补码: 正数:原码、反码、补码相同 负数:最高位为 1,其余位为原码取反,再 对整个数加 1 2021/1/18 6 原码 反码 补码 +7 00000111 00000111 00000111 -7 10000111 11111000 11111001 +0 00000000 00000000 00000000 -0 10000000 11111111 00000000 数的范围 01111111 11111111 (-127+127) 01111111 10000000 (-127+127) 01111111 10000000 (-128+127) (用一字节表示数) 纯整数的补码最小可以表示到 2n 。这时在 -2n中,符号位的 1既 表示符号“”,也表示数值 2n 。 若要一个负数变补码 ,其方法是符号位置 1,其余各位 0变 1,1变 0,然后在最 末位上加 1 。 负数补码转换成十进制数:最高位不动,其余位取反加 1 例 补码: 11111001 取反: 10000110 加 1: 10000111=-7 2021/1/18 7 2.1 C的数据类型 C语言提供了以下一些数据类型。 数据类型 构造类型 指针类型 空类型( 无值类型) void 枚举类型 enum 数组类型 结构类型 struct 联合类型 union 基本类型 整型 int 字符型 char 实型(浮点型) 单精度实型 float 双精度实型 double 数据类型决定: 1. 数据占内存字节数 ; 2. 数据取值范围 ; 3. 其上可进行的操作 2021/1/18 8 2.2 常量与变量 2.2.1 常量和符号常量 在程序运行过程中 ,其值不能被改变的量称为常量 常量区分为不同的类型: 整型 100, 125, -100, 0 实型 3.14 , 0.125, -3.789 字符型 a, b, 2 字符串 a , ab , 1232 直接 常量 2021/1/18 9 例 2.1 符号常量的使用 #define PRICE 30 #include void main ( ) int num, total; num=10; total=num * PRICE; printf(total=%d n,total); 符号常量 : 用一个标识符代表一个常量。 符号常量的值在其作用域内不能改变 , 也不能再被赋值。 运行结果: total=300 说明: 程序中用 #define命令行定义 PRICE 代表常量 30,此后凡在本文件中出现的 PRICE都代表 30,可以和常量一样进行运算 说明: 如再用赋值语句给 PRICE赋值是错的 PRICE=40; /* 错误,不能给符号常量赋值 2021/1/18 10 2.2 常量与变量 2.2.2 变量 变量代表内存中具有特定属性的一个存储单 元,它用来 存放数据 ,这就是变量的值,在 程序运行期间,这些值是可以改变的。 变量名 实际上是一个以一个名字对应代表一 个 地址 ,在对程序编译连接时由编译系统给 每一个变量名分配对应的内存地址。从变量 中取值,实际上是通过变量名找到相应的内 存地址,从该存储单元中读取数据。 2021/1/18 11 2.2 常量与变量 变量命名的规定: 语言规定标识符只能由 字母、数字和下划线三种字符组成,且第一 个字符必须为字母或下划线。 例: sum, _total, month, Student_name, lotus_1_2_, BASIC, li_ling M.D.John, ¥ 123,3D64,ab 2021/1/18 12 2.2 常量与变量 注意: 编译系统将大写字母和小写字母认为是两 个不同的字符。 建议变量名的长度最好不要超过 8个字符。 在选择变量名和其它标识符时,应注意做 到 见名知意 ,即选有含意的英文单词 (或其缩写)作标识符。 要求对所有用到的变量作强制定义,也就 是 先定义,后使用 。 2021/1/18 13 2.3 整型数据 2.3.1整型常量的表示方法 整型常量即整常数。在语言中,整常数 可用以下三种形式表示: (1)十进制整数。 如: 123, -456, 4。 (2)八进制整数。以 0开头的数是八进制数。 如: 0123表示八进制数 123,等于十进制数 83,-011表示八进制数 -11,即十进制数 -9。 2021/1/18 14 2.3 整型数据 (3)十六进制整数。以 0 x开头的数是 16进制数。 如: 0 x123,代表 16进制数 123,等于十进制数 291。 -0 x12等于十进制数 10。 2.3.2 整型变量 (1)整型数据在内存中的存放形式 数据在内存中是以二进制形式存放的。 如 : int i; /* 定义为整型变量 */ i=10; /* 给 i赋以整数 10 */ 2021/1/18 15 2.3 整型数据 注意: 十进制数 10的二进制形式为 1010, Turbo C 2.0和 Turbo C+ 3.0为一个整型变量在 内存中分配 2个字节的存储单元 (不同的编 译系统为整型数据分配的字节数是不相同 的, VC+ 6.0则分配 4个字节)。 数值是以补码 (complement) 表示的。 2021/1/18 16 2.3 整型数据 (2)整型变量的分类 共六种 有符号基本整型 有符号短整型 有符号长整型 无符号基本整型 无符号短整型 无符号长整型 (signed)int (signed)short (int ) (signed) long (int) unsigned int unsigned short (int) unsigned long (int) 注意: 括号表示其中的内容是可选的 . 2021/1/18 17 2.3 整型数据 整数类型的有关数据: 类型 类型说明符 长度 数的范围 基本型 int 2字节 -32768 32767 短整型 short 2字节 -215 215-1 长整型 long 4字节 -231 231-1 无符号整型 unsigned 2字节 0 65535 无符号短整型 unsigned short 2字节 0 65535 无符号长整型 unsigned long 4字节 0( 232-1) 2021/1/18 18 2.3 整型数据 例如:整数 13在内存中实际存放的情况: 2021/1/18 19 2.3 整型数据 (3)整型变量的定义 : 规定在程序中所有用到的变量都必须在 程序中定义,即 强制类型定义 。 例如 : int a,b(指定变量、为整型) unsigned short c,d;(指定变量、为 无符号短整型) long e,f;(指定变量、为长整型) 2021/1/18 20 例 2.2 整型变量的定义与使用 #include void main() int a,b,c,d; /* 指定、为整 * unsigned ; * * 12; -24; 10; ; printf( , ,); 说明: 可以看到不同种类的整型数据可以 进行算术运算 运行结果: , 2021/1/18 21 例 2.3 整型数据的溢出 #include void main() int a,b; a=32767; b=a+1; printf(“%d,%d n”,a,b); 说明: 数值是以补码表示的。一个整型变量 只能容纳 -32768 32767范围内的数,无法 表示大于 32767或小于 -32768的数。遇此情 况就发生“溢出”。 运行结果: 32767,-32768 2021/1/18 22 在 C中,用高位置 1来表示负数, int型占两个字节共 16位, 32768的二进制是 10000000,00000000,高位为 1,系统会认 为是负数,所以 32768需要用长型表示,占四个字节。最高 位就不是 1了。 (00000000,00000000,10000000,00000000) -32768在内存中的表示是 10000000,00000000。 过程是:先读入正值 32768( 10000000,00000000),再取反 ( 01111111,11111111),再加 1(10000000,00000000) 2021/1/18 23 2021/1/18 24 2021/1/18 25 2.3 整型数据 2.3.3 整型常量的类型 (1)一个整数,如果其值在 -32768 +32767范 围内,认为它是 int型,它可以赋值给 int型 和 long int型变量。 (2) 一个整数,如果其值超过了上述范围, 而在 -2147483637 +2147483647范围内,则 认为它是为长整型。可以将它赋值给一个 long int型变量。 2021/1/18 26 2.3 整型数据 (3) 如果所用的 C版本(如 Turbo C)分配给 short int与 int型数据在内存中占据的长度 相同,则它的表数范围与 int型相同。因此 一个 int型的常量同时也是一个 short int型 常量,可以赋给 int型或 short int型变量。 2021/1/18 27 2.3 整型数据 (4) 一个整常量后面加一个字母 u或 U,认 为是 unsigned int型,如 12345u,在内存 中按 unsigned int规定的方式存放 (存储 单元中最高位不作为符号位,而用来存储 数据 )。如果写成 -12345u,则先将 -12345 转换成其补码 53191,然后按无符号数存 储。 2021/1/18 28 Unsigned int 占 2个字节( 16位)。 12345 二进制 -12345 二进制(补码) 原: 补: Unsigned: =53191 2021/1/18 29 2.3 整型数据 (5) 在一个整常量后面加一个字母 l或 L ,则认为是 long int型常量。 例如: 123l.432L.0L 用于函数调用中。 如果函数的形参为 long int型,则要 求实参也为 long int型。 2021/1/18 30 2.4 浮点型数据 2.4.1浮点型常量的表示方法 两种表 示形式 小数 指数 0.123 3e-3 注意 :字母 e(或 E)之前必须有数字,且 e后面的 指数必须为整数 1e3、 1.8e-3、 -123e-6、 -.1e-3 e3、 2.1e3.5、 .e3、 e 2021/1/18 31 2.4 浮点型数据 规范化的指数形式: 在字母 e(或 E)之前的小数部分中,小数点左边 应有一位(且只能有一位)非零的数字 . 例如 : 123.456可以表示为: 123.456e0, 12.3456e1, 1.23456e2, 0.123456e3, 0.0123456e4, 0.00123456e 其中的 1.23456e2称为 规范化的指数形式 。 2021/1/18 32 2.4 浮点型数据 2.4.2 浮点型变量 (1)浮点型数据在内存中的存放形式 一个浮点型数据一般在内存中占 4 个字节 (32位 )。与整型数据的存储方 式不同,浮点型数据是按照 指数形式 存储的。系统把一个浮点型数据分成 小数部分和指数部分,分别存放。指 数部分采用规范化的指数形式。 2021/1/18 33 类型 位数 数的范围 有效数字 float 32 10-37 1038 67 位 double型 64 10-30710308 1516位 long double 128 10-4931104932 1819位 2.4 浮点型数据 (2) 浮点型变量的分类 浮点型变量分为单精度( float型)、双精度 ( double型)和长双精度型( long double)三类 形式。 2021/1/18 34 例 2.4 浮点型数据的舍入误差 #include void main() float a,b; a = 123456.789e5; b = a + 20 ; printf(“%f n”,b); 说明: 一个浮点型变量只能保证的有效数字是 7位有效数字,后面的 数字是无意义的,并不准确地表示该数。应当避免将一个很大的数 和一个很小的数直接相加或相减,否则就会“丢失”小的数 运行结果: 123456.789e5 2021/1/18 35 2.4 浮点型数据 2.4.3 浮点型常量的类型 C编译系统将浮点型常量作为双精度来处理。 例如 : f = 2.45678 * 4523.65 系统先把 2.45678和 4523.65作为双精度数 ,然后进行相乘的运算,得到的乘也是一个 双精度数。最后取其前 7位赋给浮点型变量 f 。如是在数的后面加字母 f或 F(如 1.65f, 654.87F),这样编译系统就会把它们按单精 度( 32位)处理。 2021/1/18 36 2.5 字符型数据 2.5.1 字符常量 (1)用单引号包含的一个字符是字符型常量 (2)只能包含一个字符 a,A, 1 abc、 “ a” 2021/1/18 37 2.5 字符型数据 有些以 ”开头的特殊字符称为转义字符 n 换行 t 横 向跳格 r 回 车 反 斜杠 ddd ddd表示 1到 3位八进制数字 xhh hh表示 1到 2位十六进制数字 2021/1/18 38 例 2.5 转义字符的使用 打印机上的显示结果: fab c gde h jik 2021/1/18 39 2.5 字符型数据 2.5.2字符变量 字符型变量用来存放字符常量 , 注意只能放 一个字符 。 字符变量的定义形式如下: char c1,c2; 在本函数中可以用下面语句对 c1,c2赋值: c1 a; c2 b ; 一个字符变量在内存中占一个字节。 2021/1/18 40 2.5 字符型数据 2.5.3 字符数据在内存中的存储形式及其使用方法 一个字符常量存放到一个字符变量中,实际上并 不是把该字符的字型放到内存中去,而是将该字 符的相应的 ASCII代码放到存储单元中。这样使 字符型数据和整型数据之间可以通用。 注意 : 一个字符数 据既可以以 字符形式输 出,也可以 以整数形式 输出。 2021/1/18 41 例 2.6 向字符变量赋以整数。 #include void main() char c1,c2; c1=97; c2=98; printf(“%c %c n”,c1,c2); printf(“%d %d n”,c1,c2); 说明: 在第和第 4行中,将整数 97和 98分别赋 给 c1和 c2,它的作用相当于以下两个赋值语句: c1 ;c2 ; 因为 a 和 b 的 ASCII码为 97和 98 运行结果: 97 98 2021/1/18 42 例 2.7 大小写字母的转换 #include void main() char c1,c2; c1=a; c2=b; c1=c1-32; c2=c2-32; printf(“ c c , c1,c2); 说明: 程序的作用是将两个小写字母 a和 b转 换成大写字母 A和 B。从代码表中 可以看到每一个小写字母比它相应的大写字 母的 ASCII码大 32。语言允许字符数据与 整数直接进行算术运算。 运行结果: 2021/1/18 43 2.5 字符型数据 说明: 有些系统(如 Turbo C)将字符变量定义为 signed char型。其存储单元中的最高位作为符号位,它的取 值范围是 -128 127。如果在字符变量中存放一个 ASCII码为 0 127间的字符,由于字节中最高位为 0, 因此用 %d输出字符变量时,输出的是一个正整数。如 果在字符变量中存放一个 ASCII码为 128 255间的字 符,由于在字节中最高位为 1,用 %d格式符输出时, 就会得到一个负整数。 2021/1/18 44 2.5 字符型数据 2.5.4字符串常量 字符串常量是一对双撇号括起来的字符序列 . 合法的字符串常量 : How do you do.”, “CHINA”, a” , $123.45” 可以输出一个字符串,如 printf(“How do you do.”); 2021/1/18 45 2.5 字符型数据 是字符常量, 是字符串常量,二 者不 同。 如: 假设被指定为字符变量 : char c c=a; ” a” ; c” CHINA”; 结论: 不能把一个字符串常量赋给一个字符 变量。 2021/1/18 46 规定:在每一个字符串常量的结尾加一个 字 符 串结束标志 ,以便系统据此判断字符串是否结束。 规定以字符 作为字符串结束标志。 如: 如果有一个字符串常量” ,实 际上在内存中是: C H I N A 0 它占内存单元不是个字符,而是个字符, 最后一个字符为。但在输出时不输出 。 2.5 字符型数据 2021/1/18 47 2.6 变量赋初值 字符串常量 (1)语言允许在定义变量的同时使变量初始化 如 : int a=3; / 指定为整型变量,初值为 float f=3.56; / 指定为浮点型变量,初值 为 .56 char c= a; / 指定为字符变量,初值 为 a 2021/1/18 48 2.6 变量赋初值 (2)可以使被定义的变量的一部分赋初值。 如 : int a,b,c=5; 表示指定、为整型 变量,但只对初始化, c的初值为 (3)如果对几个变量赋以同一个初值, 应写成: int a=3,b=3,c=3; 表示、 的初值都是。 不能写成 int a=b=c=3; 注意: 初始化不是在编译阶段完成的而是在程序运 行时执行本函数时赋初值的,相当于有一个赋值语 句。 2021/1/18 49 2.7 各类数值型数据间的混合运算 混合运算: 整型(包括 int,short,long)、浮 点型(包括 float,double)可以混合运算。 在进行运算时,不同类型的数据要先转换成 同一类型 ,然后进行运算 . 说明: 这种类型转换是由 系统自动进行的。 2021/1/18 50 2.8 算术运算符和算术表达式 2.8.1 运算符简介 的运算符有以下几类: (1)算术运算符 ( + - * / %) (2)关系运算符 (!) (3)逻辑运算符 (! |) (4)位运算符 ( | ) (5)赋值运算符 (及其扩展赋值运算符) (6)条件运算符 (?:) (7)逗号运算符 (,) (8)指针运算符 ( *和) (9)求字节数运算符() (10)强制类型转换运算符( (类型) ) (11)分量运算符( -) (12)下标运算符( ) (13)其他 (如函数调用运算符() 2021/1/18 51 2.8 算术运算符和算术表达式 2.8.2 算术运算符和算术表达式 (1)基本的算术运算符 : ( 加法运算符,或正值运算符。如 :、) ( 减法运算符,或负值运算符。如 :、) * (乘法运算符。如 : *) ( 除法运算符。如 :) ( 模运算符,或称求余运算符,两侧均应为整型 数据,如 :的值为)。 2021/1/18 52 2.8 算术运算符和算术表达式 (2) 算术表达式和运算符的优先级与结合性基 本的算术运算符 : 用算术运算符和括号将运算对象 (也称操作数) 连接起来的、符合语法规则的式子,称为算 术表达式。运算对象包括常量、变量、函数等。 例如 : * .5 a 是一个合法的表达式 2021/1/18 53 语言规定了运算符的优先级和结合性。 在表达式求值时,先按运算符的优先级别高低 次序执行,例如先乘除后加减。 规定了各种运算符的结合方向 (结合性 ) 算术运算符的结合方向为“自左至右”,即先 左后右 。 2.8 算术运算符和算术表达式 2021/1/18 54 2.8 算术运算符和算术表达式 (3)强制类型转换运算符 可以利用强制类型转换运算符将一个表达式转换成 所需类型。 一般形式 :(类型名)(表达式) 例如: (double) 将转换成 double类型 (int)(x+y) 将 x+y的值转换成整型 (float)( 5%3) 将 5%3的值转换成 float型 2021/1/18 55 例 2.8 强制类型转换。 #include void() ; ; ; (); printf(x=%f, i=%dn, x, i); 说明: 有两种类型转换,一种是在运算时不必用 户指定,系统自动进行的类型转换,如 3+6.5。 第二种是强制类型转换。当自动类型转换不能实 现目的时,可以用强制类型转换。 运行结果: x 3.600000, i=3 2021/1/18 56 2.8 算术运算符和算术表达式 (4) 自增、自减运算符 作用是使变量的值增或减 如 : ,(在使用之前,先使的值加 (减) ,(在使用之后,使的值加( 减) 2021/1/18 57 2.8 算术运算符和算术表达式 i+与 +i的区别: 是先执行后,再使用的值; 是先使用的值后,再执行。 例如: ; i的值先变成 4, 再赋给 ,j的值均为 ; 先将 i的值 3赋给 ,的值为,然后变为 2021/1/18 58 2.8 算术运算符和算术表达式 注意: (1)自增运算符(),自减运算符(), 只能用于变量,而不能用于常量或表达式, (2)和的结合方向是 自右至左 。 自增(减)运算符常用于循环语句中使循环变量 自动加。也用于指针变量,使指针指向下一个地址 2021/1/18 59 2.8 算术运算符和算术表达式 (5) 有关表达式使用中的问题说明 ANSI C并没有具体规定表达式中的子表达式的求 值顺序,允许各编译系统自己安排。 例如 : 对表达式 a = f1( )+f2( ) 并不是所有的编译系统都先调用 f1( ), 然后 调用 f2( )。在有的情况下结果可能不同。有时会出 现一些令人容易搞混的问题,因此务必要小心谨慎 。 2021/1/18 60 2.8 算术运算符和算术表达式 语言中有的运算符为一个字符,有的运算符由 两个字符组成 ,为避免误解,最好采取大家都能理 解的写法。 例如 : 不要写成 i+j的形式,而应写成 (i+)+j的形式 2021/1/18 61 2.8 算术运算符和算术表达式 在调用函数时,实参数的求值顺序,标准并无统 一规定。 例如: 的初值为,如果有下面的函数调用: printf( , , i+) 在有的系统 中,从左至右求值,输出“,”。在多数系 统中对函数参数的求值顺序是自右而左, 函数输出的是“,”。以上这种写法 不宜提倡, 最好改写成 j = i+; printf(%d, %d, j, i) 不要写出别人看不懂的也 不知道系统会怎样执行程 序 2021/1/18 62 2.9 赋值运算符和赋值表达式 (1)赋值运算符 赋值符号“”就是赋值运算符,它的作用是 将一个数据赋给一个变量。如“”的作用 是执行一次赋值操作(或称赋值运算)。把常 量赋给变量。也可以将一个表达式的值赋 给一个变量 . 2021/1/18 63 2.9 赋值运算符和赋值表达式 (2)类型转换 如果赋值运算符两侧的类型不一致 , 但都 是数值型或字符型时 , 在赋值时要进行类型 转换 。 将浮点型数据 ( 包括单 、 双精度 ) 赋给整 型变量时 , 舍弃浮点数的小数部分 。 如 :为整型变量 , 执行 i=3.56” 的结果是使 的值为 , 以整数形式存储在整型变量中 . 2021/1/18 64 2.9 赋值运算符和赋值表达式 将整型数据赋给单、双精度变量时,数值不变, 但以浮点数形式存储到变量中 如 : 将 23赋给 float变量,即执行 23,先 将 23转换成 23 00000,再存储在中。 将 23赋给 double型变量,即执行 23,系 统将 23补足有效位数字为 23 00000000000000, 然后以双精度浮点数形式存储到变量中。 2021/1/18 65 2.9 赋值运算符和赋值表达式 将一个 double型数据赋给 float变量时,截取其前 面 7位有效数字,存放到 float变量的存储单元( 4个 字节)中。但应注意数值范围不能溢出。 如 :float f;double d=123.456789e100; f=d; 就出现溢出的错误。 如果将一个 float型数据赋给 double变量时,数值不 变,有效位数扩展到 16位,在内存中以 8个字节存储 2021/1/18 66 2.9 赋值运算符和赋值表达式 字符型数据赋给整型变量时,由于字符只 占 1个字节,而整型变量为个字节,因此将 字符数据(个二进位)放到整型变量存储 单元的低位中。 2021/1/18 67 第一种情况: 低位对应、高位补零 若所用系统将字符处理为无符 号字符类型,或程序已将字符变量 定义为 unsigned char型,则将字 符的位放到整型变量低位,高 位补零。 例如: 将字符 376赋给 int型变量 第二种情况: 符号扩展 若所用系统(如 Turbo C+)将字符处理为带符号( signed char)时,若字符最高位为,则整型变量高位补;若字 符最高位为,则高位全补。这称为 符号扩展 ,这样 做的目的是使数值保持不变,如变量(字符 376)以整数 形式输出为,的值也是。 2021/1/18 68 2.9 赋值运算符和赋值表达式 将一个 int、 short、 long型数据赋给一个 char型变 量时,只将其低 8位原封不动地送到 char型变量(即 截断)。 例如: int i=289;char c=a;c=i; c的值为 33, 如果用“ %c” 输 出 c,将得到字符“ !” !的 ASCII码为 33。 赋值情况 : 2021/1/18 69 2.9 赋值运算符和赋值表达式 将带符号的整型数据( int型)赋给 long型变 量时,要进行符号扩展,将整型数的 16位送到 long型低 16位中 : 如果 int型数据为正值(符号位为),则 long 型变量的高 16位补; 如果 int型变量为负值(符号位为),则 long 型变量的高 16位补,以保持数值不改变。 反之,若将一个 long型数据赋给一个 int型变量 ,只将 long型数据中低 16位原封不动地送到整型 变量(即截断)。 2021/1/18 70 2.9 赋值运算符和赋值表达式 例如: int a; long b; a=b 赋值如 : 如果 65536,则赋值后值为。 2021/1/18 71 2.9 赋值运算符和赋值表达式 将 unsigned int型数据赋给 long int型变量时,不 存在符号扩展问题,只需将高位补即可。将一个 unsigned类型数据赋给一个占字节数相同的非 unsigned型整型变量(例如: unsigned int -int, unsigned long-long, unsigned short -short),将 unsigned型变量的内容原样送到非 unsigned型变量中,但如果数据范围超过相应整型的 范围,则会出现数据错误。 2021/1/18 72 2.9 赋值运算符和赋值表达式 例如: unsigned int 65535; int b;; 将整个送到中 ,由于是 int,第位是符号位, 因此 b成了负数。根据补码知识可知,的值为 -1, 可以用 printf( %d,b); 来验证。 将非 unsigned型数据赋给长度相同的 unsigned型变 量,也是原样照赋(符号位也作为数值一起传送)。 2021/1/18 73 例 2.9 有符号数据传送给无符号变量。 #include void main() unsigned ; int ; ; print( n ,); 说明: “ %u” 是输出无符号数时所用的格式符。如果 为正值,且在 32767之间,则赋值后数值不变。 运行结果: 2021/1/18 74 2.9 赋值运算符和赋值表达式 (3) 复合的赋值运算符 在赋值符 “ ” 之前加上其他运算符 , 可以构成复 合的运算符 。 例如 : 等价于 * 等价于 *( ) 等价于 2021/1/18 75 2.9 赋值运算符和赋值表达式 为便于记忆 , 可以这样理解: a += b (其中 a为变量 , b为表达式 ) a += b(将有下划线的 a+”移到 =”右侧 ) |_ a = a + b (在 =”左侧补上变量名 a) 注意 :如果是包含若干项的表达式,则相当于它有 括号。 如: x %= y+3 x %= (y+3) |_ x = x %(y+3)(不要错写成 x=x%y+3) 凡是二元(二目)运 算符,都可以与赋值 符一起组合成复合赋 值符。 语言规定可以使用种复合赋值运算符: , *, , , , | 2021/1/18 76 2.9 赋值运算符和赋值表达式 (4) 赋值表达式 由赋值运算符将一个变量和一个表达式连接 起来的式子称为 “ 赋值表达式 ” 。 一般形式为 : 例如 : “ 5”是一个赋值表达式 2021/1/18 77 2.9 赋值运算符和赋值表达式 对赋值表达式求解的过程是: 求赋值运算符右侧的表达式的值 ; 赋给赋值运算符左侧的变量。 例如 : 赋值表达式 =3*5”的值为 15,执行表 达式后,变量 a的值也是 15。 注意 : 一个表达式应该有一个值 2021/1/18 78 2.9 赋值运算符和赋值表达式 左值 (lvalue) : 赋值运算符左侧的标识符 变量可以作为左值 ; 而表达式就不能作为左值 (如 a+b);赋值表达式可以 ; 常变量也不能作为左值, 右值 (lvalue) :出现在赋值运算符右侧的表达式 左值也可以出现在赋值运算符右侧,因而左值 都可以作为右值。 2021/1/18 79 2.9 赋值运算符和赋值表达式 赋值表达式中的“表达式”,又可以是一个赋值表 达式。 例如 : a=(b=5) 分析 :括弧内的 b=5”是一个赋值表达式,它 的值等于 5。执行表达式 a=(b=5)”相当于执 行 b=5”和 a b”两个赋值表达式。 赋值运算 符 按照 自右而左 的结合顺序,因此, (b 5)” 外面的括弧可以不要,即 a=(b=5)”和 a=b=5” 等价。 2021/1/18 80 2.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 2021/1/18 81 2.9 赋值运算符和赋值表达式 赋值表达式也可以包含复合的赋值运算符。 如: a+=a-=a*a;a初值为 12 分析 :此赋值表达式的求解步骤如下 先进行 * 的运算, 它相当 于 *, a的值为 144 132。 再进行 的运算,相当 于 =a+(-132), a的值为 132-132 -264。 2021/1/18 82 2.9 赋值运算符和赋值表达式 将赋值表达式作为表达式的一种,使赋值操 作 不仅 可以出现在赋值语句中, 而且 可以以表 达式形式出现在其他语句(如输出语句、循环 语句等)中。 如: printf(%d, a=b); 分析 :如果 b的值为 3, 则输出 a的值 (也是表 达式 a=b的值 )为 3。在一个语句中完成 了赋值和输出双重功能。 2021/1/18 83 2.10 逗号运算符和逗号表达式 逗号运算符 :将两个表达式连接起来 ,又称为 顺序求 值运算符 如: 5, 一般形式 : 表达式,表达式 求解过程: 先求解表达式,再求解表达式。整个逗号 表达式的值是表达式的值。 逗号表达式 的 值为 14 2021/1/18 84 2.10 逗号运算符和逗号表达式 例: 逗号表达式 *5, * 分析 :赋值运算符的优先级别 高于 逗号运算符, 因 此应先求解 *5。 的值为 5, 然后求解 *, 得。整个逗 号表达式的值为 。 一个逗号表达式又可以与另一个表达式组成一 个新的逗号表达式 如 :( *, *) ,a+5 先计算出的值等于,再进行 *的运算 得 60(但值未变,仍为 15),再进行 得,即整个表达式的值为。 2021/1/18 85 2.10 逗号运算符和逗号表达式 逗号表达式的一般形式可以扩展为 表达式,表达式,表达式, ,表达式 它的值为表达式的值。 逗号运算符是所有运算符中级别 最低 的 例 : (, *) , *3 赋值表达式, 将一个逗号表 达式的值赋给 ,的值等 于 逗号表达式,包括 一个赋值表达式和 一个算术表达式, 的值为 ,整个 逗号表达式的值为 18。 2021/1/18 86 2.10 逗号运算符和逗号表达式 注意 :并不是任何地方出现的逗号都是作为逗 号运算符。例如函数参数也是用逗号来间 隔的。 如 : printf(“%d,%d,%d”,a,b,c); “,” 并不是一个逗 号表达式,它 是 printf函数的 3个参数 printf(“%d,%d,%d”,(a,b,c),b,c); “(,)” 是一个逗号表达式, 它的值等于的值。 2021/1/18 87 2.11 关系运算符和关系表达式 1.关系运算符及其优先次序 1. (小于 ) 2. (大于 ) 4. = (大于或等于 ) 5. = (等于 ) 6. != (不等于 ) 优先级相同(高) 优先级相同(低) 说明: 关系运算符的优先级低于算术运算符 关系运算符的优先级高于赋值运算符 2021/1/18 88 2.11 关系运算符和关系表达式 2.关系表达式 用关系运算符将两个表达式(可以是算术表达式或 关系表达式,逻辑表达式,赋值表达式,字符表达式) 接起来的式子,称关系表达式 例: ab,a+bb+c,(a=3)(b=5),ab)(bb”的值为真,表达式的值为 1。 C语言中没有专用 的逻辑值, 1代表 真, 0代表假 2021/1/18 89 2.12 逻辑运算符和逻辑表达式 1.逻辑运算符及其优先次序 (1)& (逻辑与 ) 相当于其他语言中的 AND (2)| (逻辑或 ) 相当于其他语言中的 OR (3)! (逻辑非 ) 相当于其他语言中的 NOT 例: a&b 若 a,b为真,则 a&b为真。 a|b 若 a,b之一为真,则 a|b为真。 ! a 若 a为真,则 !a为假。 优先次序: ! (非 )-&()-|() 逻辑运算符中的 &”和 |”低于关系运算符, !”高于算 术运算符 2021/1/18 90 2.12 逻辑运算符和逻辑表达式 2.逻辑表达式 用逻辑运算符将关系表达式或逻辑量连接起来的式子就 是逻辑表达式。 逻辑表达式的值应该是一个逻辑量 真 或 假 。 例: 设 a=4, b=5: !a的值为 0 a&b的值为 1 a|b的值为 1 !a|b的值为 1 4&0|2的值为 1 逻辑运算结果 : 1代表真 ,0代表假 运算对象 : 任何非零的数值被认作真 2021/1/18 91 2.12 逻辑运算符和逻辑表达式 例: 53&84-!0 自左向右运算 1&0逻辑值为 0 83逻辑值为 1 表达式值为 0 2021/1/18 92 2.12 逻辑运算符和逻辑表达式 在逻辑表达式的求解中,并不是所有的逻辑运算符都要被执行。 (1)a&b&c 只有 a为真时,才需要判断 b的值,只有 a和 b都为真时, 才需要判断 c的值。 (2)a|b|c 只要 a为真,就不必判断 b和 c的值,只有 a为假,才 判断 b。 a和 b都为假才判断 c 例 :(m=ab)&(n=cd) 当 a=1,b=2,c=3,d=4,m和 n的原值为 1时,由于 ab”的值 为 0,因此 m=0,而 n=cd”不被执行,因此 n的值不是 0而 仍保持原值 1。 2021/1/18 93 2.12 逻辑运算符和逻辑表达式 用逻辑表达式来表示闰年的条件 能被 4整除,但不能被 100整除。 能被 4整除,又能被 400整除。 答 (year%4=0&year%100!=0)|year%400=0 案 值为真 (1)是闰年,否则为非闰年。
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 图纸专区 > 课件教案


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!