谭浩强C语言第3章数据类型

上传人:博****1 文档编号:568457140 上传时间:2024-07-24 格式:PPT 页数:68 大小:946.02KB
返回 下载 相关 举报
谭浩强C语言第3章数据类型_第1页
第1页 / 共68页
谭浩强C语言第3章数据类型_第2页
第2页 / 共68页
谭浩强C语言第3章数据类型_第3页
第3页 / 共68页
谭浩强C语言第3章数据类型_第4页
第4页 / 共68页
谭浩强C语言第3章数据类型_第5页
第5页 / 共68页
点击查看更多>>
资源描述

《谭浩强C语言第3章数据类型》由会员分享,可在线阅读,更多相关《谭浩强C语言第3章数据类型(68页珍藏版)》请在金锄头文库上搜索。

1、第三章 数据类型、运算符与表达式v各种进制之间的转换l二进制、八进制、十六进制转换成十进制u方法:按权相加1v各种进制之间的转换(整数)l二进制、八进制、十六进制转换成十进制u方法:按权相加l十进制转换成二进制、八进制、十六进制u原理:u方法:连续除以基,从低到高记录余数,直至商为0例 把十进制数59转换成二进制数5922921427232120(59)10=(111011)21101111 1 1 0 1 1余余余余余余例 把十进制数159转换成八进制数1598198280(159)10=(237)82 3 7 余 7余 3余 2例 把十进制数459转换成十六进制数4591628161160

2、(459)10=(1CB)161 C B 余11余12余 12l二进制与八进制之间的转换u二进制转换成八进制:从右向左,每3位一组(不足3位左补0),转换成八进制u八进制转换成二进制:用3位二进制数代替每一位八进制数例 (1101001)2=(001,101,001)2=(151)8例 (246)8=(010,100,110)2=(10100110)2000 0001 1010 2011 3100 4101 5110 6111 73l二进制与十六进制之间的转换u二进制转换成十六进制:从右向左,每4位一组(不足4位左补0),转换成十六进制u十六进制转换成二进制:用4位二进制数代替每一位十六进制数

3、例 (11010101111101)2=(0011,0101,0111,1101)2=(357D)16例 (4B9E)16=(0100,1011,1001,1110)2=(100101110011110)20000 00001 10010 20011 30100 40101 50110 60111 71000 81001 91010 A1011 B1100 C1101 D1110 E1111 F4字节和位v内存以字节为单元组成v每个字节有一个地址v一个字节一般由8个二进制位组成v每个二进位的值是0或101234567012345678910.5数值的表示方法原码、反码和补码v原码:最高位为符号

4、位,其余各位为数值本身的绝对值v反码:l正数:反码与原码相同l负数:符号位为1,其余位对原码取反v补码:l正数:原码、反码、补码相同l负数:最高位为1,其余位为原码取反,再对整个数加13126912457810119-5=49+7=16=(4)126原码反码补码+7000001110000011100000111-7100001111111100011111001+0000000000000000000000000-0100000001111111100000000数的范围0111111111111111(-127+127)0111111110000000(-127+127)011111111

5、0000000(-128+127)(用一字节表示数)v负数补码转换成十进制数:最高位不动,其余位取反加1例 补码:11111001 取反:10000110 加1: 10000111=-773.1 数据类型数据类型总表C数据类型基本类型构造类型指针类型空类型void定义类型typedef字符类型char枚举类型enum整 型实型单精度型float双精度型double数组结构体struct共用体union短整型short长整型long整型int数据类型决定:1. 数据占内存字节数2. 数据取值范围3. 其上可进行的操作8基本数据类型类型符号关键字数的表示范围所占位数整型字符型实型有无(signed

6、)int16-3276832767(signed)short16-3276832767(signed)long32-2147483648214748364716unsigned int0655353204294967295unsigned longunsigned short16065535有float323.4e-383.4e38有double641.7e-3081.7e308有char8-128127无unsigned char80255说明:数据类型所占字节数随机器硬件不同而不同,上表以IBM PC机为例:93.2 常量与变量标识符v定义:用来标识变量、常量、函数等的字符序列v组成:l只

7、能由字母、数字、下划线组成,且第一个字母必须是字母或下划线l大小写敏感l不能使用关键字v长度:最长32个字符v命名原则:l见名知意l不宜混淆 如l与I, o与0例:判断下列标识符号合法性sum Sum M.D.John day Date 3days student_name #33 lotus_1_2_3 char ab _above $123M.D.John3days#33char$123ab10u一般用大写字母u是宏定义预处理命令,不是C语句如 #define PRICE 30常量v定义:程序运行时其值不能改变的量(即常数)v分类:l符号常量:用标识符代表常量u定义格式: #define

8、符号常量 常量例 符号常量举例(ch2_1.c)#define PRICE 30main() int num,total; num=10; total=num*PRICE; printf(total=%d,total);运行结果:total=300说明:说明:说明:说明: 程序中用#define命令行定义PRICE代表常量30,此后凡在本文件中出现的PRICE都代表30,可以和常量一样进行运算说明:说明:说明:说明:如再用赋值语句给PRICE赋值是错的 PRICE=40;/* 错误,不能给符号常量赋值3.2 常量与变量11变量变量变量代表内存中具有特定属性的一个存储单元,它变量代表内存中具有特

9、定属性的一个存储单元,它用来存放数据,这就是变量的值。用来存放数据,这就是变量的值。变量名实际上是一个以一个名字对应代表一个地址,变量名实际上是一个以一个名字对应代表一个地址,在对程序编译连接时由编译系统给每一个变量名分在对程序编译连接时由编译系统给每一个变量名分配对应的内存地址。从变量中取值,实际上是通过配对应的内存地址。从变量中取值,实际上是通过变量名找到相应的内存地址,从该存储单元中读取变量名找到相应的内存地址,从该存储单元中读取数据。数据。12编译程序根据变量定义为其分配指定字节的内存单元.地址int a=1, b=-3,c;abc2字节2字节2字节地址地址.内存1-3随机数变量v概念

10、:其值可以改变的量v变量名与变量值v变量定义的一般格式: 数据类型 变量1,变量2,变量n;v变量初始化:定义时赋初值 例: int a,b,c; float data;决定分配字节数和数的表示范围合法标识符例: int a=2,b,c=4; float data=3.67; char ch=A; int x=1,y=1,z=1; int x=y=z=1;v变量的使用:先定义,后使用例1 int student; stadent=19; /Undefined symbol statent in function main 例2 float a,b,c; c=a%b; /Illegal use

11、of floating point in function main v变量定义位置:一般放在函数开头main() int a,b=2; float data; a=1; data=(a+b)*1.2; printf(“data=%fn”,data);变量定义可执行语句main() int a,b=2; a=1; float data; data=(a+b)*1.2; printf(“data=%fn”,data);133.2 常量与变量标识符v定义:用来标识变量、常量、函数等的字符序列v组成:l只能由字母、数字、下划线组成,且第一个字母必须是字母或下划线l大小写敏感l不能使用关键字v长度:最

12、长32个字符v命名原则:l见名知意l不宜混淆 如l与I, o与0例:判断下列标识符号合法性sum Sum M.D.John day Date 3days student_name #33 lotus_1_2_3 char ab _above $123M.D.John3days#33char$123ab建议变量名的长度最好不建议变量名的长度最好不要超过要超过8 8个字符个字符. .14&整型常量(整常数)v三种形式:l十进制整数:由数字09和正负号表示.如 123,-456,0l八进制整数:由数字0开头,后跟数字07表示.如0123,011l十六进制整数:由0x开头,后跟09,af,AF表示.

13、如0x123,0xff例 12 与 12L例 30000 为int型 65536 为long int 型v整型常量的类型l根据其值所在范围确定其数据类型l在整常量后加字母l或L,认为它是long int 型常量问题:0123 = ( )100x123 = ( )100xff = ( )1083291255问题:0123 = ( )100x123 = ( )100xff = ( )10 3.3 3.3 整型数据整型数据153.3.2 整型变量整型变量 (1)(1)整型数据在内存中的存放形式整型数据在内存中的存放形式 数据在内存中是以二进制形式存放的。数据在内存中是以二进制形式存放的。 如如: :

14、 intint i; /* i; /* 定义为整型变量定义为整型变量 * */ / i=10; /* i=10; /* 给给i i赋以整数赋以整数10 */10 */ 注意:注意:注意:注意:十进制数十进制数1010的二进制形式为的二进制形式为10101010,Turbo C 2.0Turbo C 2.0和和Turbo C+ 3.0Turbo C+ 3.0为为一个整型变量在内存中分配一个整型变量在内存中分配2 2个字节的存储单元个字节的存储单元( (不同的编译系统为不同的编译系统为整型数据分配的字节数是不相同的,整型数据分配的字节数是不相同的,VC+ 6.0VC+ 6.0则分配则分配4 4个字

15、节个字节) )。数值是以补码数值是以补码(complement) (complement) 表示的。表示的。 16(2)(2)整型变量的分类整型变量的分类共六种共六种有符号基本整型有符号短整型有符号长整型无符号基本整型无符号短整型无符号长整型(signed)int (signed)short (int )(signed) long (int)unsigned intunsigned short (int)unsigned long (int) 注意:注意:括号表示其中的内容是可选的括号表示其中的内容是可选的. .17整数类型的有关数据:整数类型的有关数据: 类型类型 类型说明符类型说明符 长度

16、长度 数的范围数的范围 基本型基本型 intint 2 2字节字节 -32768-327683276732767 短整型短整型 short 2short 2字节字节 -2-215152 21515-1 -1 长整型长整型 long long 4 4字节字节 -2-231312 23131-1-1 无符号整型无符号整型 unsigned unsigned 2 2字节字节 0 06553565535 无符号短整型无符号短整型 unsigned short unsigned short 2 2字节字节 0 06553565535 无符号长整型无符号长整型 unsigned long unsigned

17、 long 4 4字节字节 0 0(2 23232-1-1)18例如:整数例如:整数1313在内存中实际存放的情况:在内存中实际存放的情况:19例3.2 整型变量的定义与使用#include #include void main()() int a,b,c,d; /*指定、指定、为整型变量为整型变量* unsigned ; *指定为无符号整型指定为无符号整型变量变量* 12;-24;10; ; printf(,);,); 说明:说明:说明:说明: 可以看到不同种类的整型数据可以进行算术运算可以看到不同种类的整型数据可以进行算术运算 运行结果:运行结果: , 20例3.3 整型数据的溢出#inc

18、lude #include void main()void main() intint a,b; a,b; a=32767; a=32767; b=a+1; b=a+1; printf(printf(“%d,%dn%d,%dn”,a,b,a,b);); 说明:说明:说明:说明:数值是以补码表示的。一个整型变量只能容纳-3276832767范围内的数,无法表示大于32767或小于-32768的数。遇此情况就发生“溢出”。运行结果:运行结果: 32767,-3276832767,-32768213.3.3 3.3.3 整型常量的类型整型常量的类型 (1)(1)一个整数,如果其值在一个整数,如果其值

19、在-32768-32768+32767+32767范围内,认为它是范围内,认为它是intint型,它可以赋值给型,它可以赋值给intint型和型和long long intint型变量。型变量。 (2) (2) 一个整数,如果其值超过了上述范围,而在一个整数,如果其值超过了上述范围,而在-2147483637-2147483637+2147483647+2147483647范围内,则认为它是为长整型。可以将它赋范围内,则认为它是为长整型。可以将它赋值给一个值给一个long long intint型变量。型变量。 (3) (3) 如果所用的如果所用的C C版本(如版本(如Turbo CTurbo

20、 C)分配给分配给short short intint与与intint型数据在内存中占据的长度相同,则它的表数范围与型数据在内存中占据的长度相同,则它的表数范围与intint型型相同。因此一个相同。因此一个intint型的常量同时也是一个型的常量同时也是一个short short intint型常量,型常量,可以赋给可以赋给intint型或型或short short intint型变量。型变量。 22(4) (4) 一个整常量后面加一个字母一个整常量后面加一个字母u u或或U U,认为是认为是unsigned unsigned intint型,如型,如12345u12345u,在内存中按在内存

21、中按unsigned unsigned intint规定的规定的方式存放方式存放( (存储单元中最高位不作为符号位,而用来存储单元中最高位不作为符号位,而用来存储数据存储数据) )。如果写成。如果写成-12345u-12345u,则先将则先将-12345-12345转换成转换成其补码其补码5319153191,然后按无符号数存储。,然后按无符号数存储。(5) (5) 在一个整常量后面加一个字母在一个整常量后面加一个字母l l或或L L,则认为是则认为是long long intint型常量。型常量。 例如:例如: 123l.432L.0L123l.432L.0L 用于函数调用中。用于函数调用中

22、。如果函数的形参为如果函数的形参为long long intint型,则要求实参也为型,则要求实参也为long long intint型。型。23&实型常量(实数或浮点数)v表示形式:l十进制数形式:(必须有小数点) 如0.123, .123, 123.0, 0.0, 123.l指数形式:(e或E之前必须有数字;指数必须为整数)如12.3e3 ,123E2, 1.23e4 , e-5 , 1.2E-3.5 v实型常量的类型l默认double型l在实型常量后加字母f或F,认为它是float 型C C编译系统将浮点型常量作为双精度来编译系统将浮点型常量作为双精度来处理。处理。 例如例如:f = 2

23、.45678 * 4523.65f = 2.45678 * 4523.65 系统先把系统先把2.456782.45678和和4523.654523.65作为双作为双精度数,然后进行相乘的运算,得到的精度数,然后进行相乘的运算,得到的乘也是一个双精度数。最后取其前乘也是一个双精度数。最后取其前7 7位位赋给浮点型变量赋给浮点型变量f f。如是在数的后面加如是在数的后面加字母字母f f或或F F(如如1.65f, 654.87F1.65f, 654.87F),),这样这样编译系统就会把它们按单精度(编译系统就会把它们按单精度(3232位)位)处理处理. .24规范化的指数形式:规范化的指数形式:

24、在字母在字母e e(或(或E E)之前的小数部分中,小数点左边之前的小数部分中,小数点左边应有一位(且只能有一位)非零的数字应有一位(且只能有一位)非零的数字. . 例如例如: : 123.456123.456可以表示为:可以表示为: 123.456e0, 12.3456e1, 1.23456e2, 123.456e0, 12.3456e1, 1.23456e2, 0.123456e3, 0.0123456e4, 0.00123456e0.123456e3, 0.0123456e4, 0.00123456e 其中的其中的1.23456e31.23456e3称为称为“规范化的指数形式规范化的指数

25、形式”。253.4.2 浮点型变量浮点型变量(1)(1)浮点型数据在内存中的存放形式浮点型数据在内存中的存放形式 一个浮点型数据一般在内存中占一个浮点型数据一般在内存中占4 4个字节个字节(32(32位位) )。与整。与整型数据的存储方式不同,浮点型数据是按照指数形式存储型数据的存储方式不同,浮点型数据是按照指数形式存储的。系统把一个浮点型数据分成小数部分和指数部分,分的。系统把一个浮点型数据分成小数部分和指数部分,分别存放。指数部分采用规范化的指数形式。别存放。指数部分采用规范化的指数形式。26类型类型 位数位数 数的范围数的范围 有效数字有效数字float float 32 32 10 1

26、0-37 -37 101038 38 6 67 7 位位doubledouble型型 6464 10 10-307-3071010308308 15 151616位位long double 128 10long double 128 10-4931-493110104932 4932 18181919位位 3.4 浮点型数据浮点型数据(2) (2) 浮点型变量的分类浮点型变量的分类 浮点型变量分为单精度(浮点型变量分为单精度(floatfloat型)、双精度(型)、双精度(doubledouble型)和长双精度型(型)和长双精度型(long doublelong double)三类形式。三类形

27、式。例 float a;a=111111.111; /* a=111111.1*/double b;b=111111.111; /* b=111111.111*/27例3.4 浮点型数据的舍入误差#include #include void main()void main()float a,b;float a,b; a = 123456.789e5; a = 123456.789e5; b = a + 20 ; b = a + 20 ; printf(printf(“%fn%fn”,b,b);); 说明:说明:说明:说明:一个浮点型变量只能保证的有效数字是7位有效数字,后面的数字是无意义的,并

28、不准确地表示该数。应当避免将一个很大的数和一个很小的数直接相加或相减,否则就会“丢失”小的数运行结果:运行结果: 123456.789e5123456.789e528&字符常量v定义:用单引号括起来的单个普通字符或转义字符. v字符常量的值:该字符的ASCII码值转义字符及其含义:转义字符含义nvradddtbf“xhh转义字符含义换行垂直制表回车响铃单引号3位8进制数代表的字符水平制表退格换页反斜线双引号2位16进制数代表的字符如 101 -A 012 -n 376 - x61 -a 60 -0 483 -()例:A-101-x41-65如 A65, a97, 048 , n10如 a A

29、? n 101v转义字符:反斜线后面跟一个字符或一个代码值表示例 转义字符举例(ch2_001.c,ch2_004.c) main() printf(101 x42 Cn); printf(I say:How are you?n); printf(C Programn); printf(Turbo C);运行结果:(屏幕显示)A B CIsay:”How are you?”C ProgramTurbo C例 main() printf(“Yb=n”); 运行结果:屏幕显示:=打印机输出:29 3.5 3.5 字符型数据字符型数据 3.5.23.5.2字符变量字符变量字字符符型型变变量量用用来来

30、存存放放字字符符常常量量,注注意意只只能能放放一个字符。一个字符。字符变量的定义形式如下:字符变量的定义形式如下:char c1,c2;char c1,c2;可以用下面语句对可以用下面语句对c1,c2c1,c2赋值:赋值: c1c1aa;c2c2 b b ;一个字符变量在内存中占一个字节。一个字符变量在内存中占一个字节。 30 3.5 字符型数据字符型数据 3.5.3 字符数据在内存中的存储形式及其使用方法字符数据在内存中的存储形式及其使用方法一个字符常量存放到一个字符变量中,实际上并不是把一个字符常量存放到一个字符变量中,实际上并不是把该字符的字型放到内存中去,而是将该字符的相应的该字符的字

31、型放到内存中去,而是将该字符的相应的ASCIIASCII代码放到存储单元中。这样使字符型数据和整型数代码放到存储单元中。这样使字符型数据和整型数据之间可以通用。据之间可以通用。注意注意: : 一个字符数据一个字符数据既可以以字既可以以字符形式输出,符形式输出,也可以以整也可以以整数形式输出。数形式输出。31例3.6 向字符变量赋以整数。 #include #include void main()void main() char c1,c2; char c1,c2; c1=97; c1=97; c2=98; c2=98; printf(printf(“%c%c %cn %cn”,c1,c2);,

32、c1,c2); printf(printf(“%d%d %dn %dn”,c1,c2);,c1,c2); 说明:说明:说明:说明:在第和第4行中,将整数97和98分别赋给c1和c2,它的作用相当于以下两个赋值语句:c1;c2; 因为a和b的ASCII码为97和98运行结果:运行结果: 97 9897 9832例3.7 大小写字母的转换 #include #include void main()void main() char c1,c2 char c1,c2; c1=c1=a a; ; c2= c2=b b; ;c1=c1-32;c1=c1-32;c2=c2-32;c2=c2-32; prin

33、tfprintf( (“c c cc,c1,c2c1,c2);); 说明:说明:说明:说明:程序的作用是将两个小写字母a和b转换成大写字母A和B。从代码表中可以看到每一个小写字母比它相应的大写字母的ASCII码大32。语言允许字符数据与整数直接进行算术运算。 运行结果:运行结果: 33说明:说明:说明:说明: 有些系统(如Turbo C)将字符变量定义为signed char型。其存储单元中的最高位作为符号位,它的取值范围是-128127。如果在字符变量中存放一个ASCII码为0127间的字符,由于字节中最高位为0,因此用%d输出字符变量时,输出的是一个正整数。如果在字符变量中存放一个ASCI

34、I码为128255间的字符,由于在字节中最高位为1,用%d格式符输出时,就会得到一个负整数。 34v字符常量与字符串常量不同&字符串常量v定义:用双引号(“”)括起来的字符序列v存储:每个字符串尾自动加一个 0 作为字符串结束标志h e l l o 0例 字符串“hello”在内存中a a 0例 a“a”例 空串 “”0例: char ch; ch=“A”; 例: char ch; ch=A; 结论结论:不能不能把一个字符把一个字符串常量赋给串常量赋给一个字符变一个字符变量。量。35 3.6 变量赋初值 (1)(1)语言允许在定义变量的同时使变量初始化语言允许在定义变量的同时使变量初始化如如:

35、 : intint a=3; / a=3; / 指定为整型变量,初值为指定为整型变量,初值为 float f=3.56; / float f=3.56; / 指定为浮点型变量,初值为指定为浮点型变量,初值为 .56 .56 char c= char c= a a; / ; / 指定为字符变量,初值为指定为字符变量,初值为a a 36 3.6 变量赋初值变量赋初值 (2)(2)可以使被定义的变量的一部分赋初值。可以使被定义的变量的一部分赋初值。 如如: : intint a,b,c=5 a,b,c=5; 表示指定、为整型变量,但表示指定、为整型变量,但只对初始化,只对初始化,c c的初值为的初值

36、为(3)(3)如果对几个变量赋以同一个初值,如果对几个变量赋以同一个初值, 应写成:应写成:intint a=3,b=3,c=3; a=3,b=3,c=3; 表示、的初值都是表示、的初值都是。 不能写成不能写成 intint a=b=c=3; a=b=c=3; 注意:注意:初始化不是在编译阶段完成的而是在程序运行时执行初始化不是在编译阶段完成的而是在程序运行时执行本函数时赋初值的,相当于有一个赋值语句。本函数时赋初值的,相当于有一个赋值语句。 372.3不同类型数据间的转换隐式转换v什么情况下发生l运算转换-不同类型数据混合运算时l赋值转换-把一个值赋给与其类型不同的变量时l输出转换-输出时转

37、换成指定的输出格式l函数调用转换-实参与形参类型不一致时转换v运算转换规则:不同类型数据运算时先自动转换成同一类型38doublefloatlongunsignedintchar,short低高说明:必定的转换运算对象类型不同时转换例 char ch; int i; float f; double d;ch/i + f*d - (f+i)intintdoubledoubledoubledoubledoubledoubleintintdoubledoubledoubledoubledoubledouble10+a +i*f - d/l例 int i; float f; double d; lon

38、g l;39显式转换(强制转换)v一般形式:(类型名)(表达式)例 (int)(x+y) (int)x+y (double)(3/2) (int)3.6 v说明:强制转换得到所需类型的中间变量,原变量类型不变 例 main() float x; int i; x=3.6; i=(int)x; printf(“x=%f,i=%d”,x,i); 结果:x=3.600000,i=3精度损失问题较高类型向较低类型转换时可能发生402.4 运算符和表达式C运运算算符符算术运算符:(算术运算符:(+ - * / % + -+ - * / % + -)关系运算符:(关系运算符:( = != = !=)逻辑运

39、算符:(!逻辑运算符:(! & |& |)位运算符位运算符 :(:( | & | &)赋值运算符:(赋值运算符:(= = 及其扩展)及其扩展)条件运算符:(条件运算符:(?:?:)逗号运算符:(逗号运算符:(, ,)指针运算符:(指针运算符:(* * & &)求字节数求字节数 :(:(sizeofsizeof)强制类型转换:(类型)强制类型转换:(类型)分量运算符:(分量运算符:(. -. -)下标运算符:(下标运算符:()其它其它 :(:(( ) -( ) -)41算术运算符和表达式v基本算术运算符: + - * / %l结合方向:从左向右l优先级: - -* / % - + - (2) (

40、3) (4)说明:l“-”可为单目运算符时,右结合性l两整数相除,结果为整数l%要求两侧均为整型数据例 5/2 = -5/2.0 =例 5%2 = -5%2 = 1%10 = 5%1 = 5.5%2例 5/2 = 2 -5/2.0 = -2.5例 5%2 = 1 -5%2 = -1 1%10 = 1 5%1 = 0 5.5%2 ()42v自增、自减运算符+ -l作用:使变量值加1或减1l种类:u前置 +i, -i (先执行i+1或i-1,再使用i值)u后置 i+,i- (先使用i值,再执行i+1或i-1)例 j=3; k=+j; j=3; k=j+; j=3; printf(“%d”,+j);

41、 j=3; printf(“%d”,j+); a=3;b=5;c=(+a)*b; a=3;b=5;c=(a+)*b; /k=4,j=4/k=3,j=4/4/3/c=20,a=4/c=15,a=443v自增、自减运算符+ -l作用:使变量值加1或减1l种类:u前置 +i, -i (先执行i+1或i-1,再使用i值)u后置 i+,i- (先使用i值,再执行i+1或i-1)l说明:u+ - 不能用于常量和表达式,如5+,(a+b)+u+ -结合方向: 自右向左u优先级:- + - -* / % -+ - (2) (3) (4)例 -i+ -(i+) i=3; printf(“%d”,-i+); /-

42、3 例 j+k; (j+)+k;例 -i+ i=3; printf(“%d”,-i+); 44(5) (5) 有关表达式使用中的问题说明有关表达式使用中的问题说明 ANSI C并没有具体规定表达式中的子表达式的求值顺序,允许各编译系统自己安排。 例如:对表达式 a = f1( )+f2( ) 并不是所有的编译系统都先调用f1( ), 然后调用f2( )。在有的情况下结果可能不同。有时会出现一些令人容易搞混的问题,因此务必要小心谨慎。 45语言中有的运算符为一个字符,有的运算符由两个字符组成 ,为避免误解,最好采取大家都能理解的写法。 例如:不要写成i+j的形式,而应写成 (i+)+j的形式.4

43、6在调用函数时,实参数的求值顺序,标准并无统一规定。例如:例如:的初值为,如果有下面的函数调用: printf(,i+) 在有的系统中,从左至右求值,输出“,”。在多数系统中对函数参数的求值顺序是自右而左, 函数输出的是“,”。以上这种写法不宜提倡, 最好改写成 j = i+;j = i+; printf(%dprintf(%d, %d%d, j j,i)i)47赋值运算符和表达式v简单赋值运算符l符号: =l格式: 变量标识符=表达式l作用:将一个数据(常量或表达式)赋给一个变量v复合赋值运算符l种类:+= -= *= /= %= = = &= = |=l含义: exp1 op= exp2e

44、xp1 op= exp2 exp1 = exp1 op exp2exp1 = exp1 op exp2a+=3a=a+3x*=y+8x=x*(y+8)x%=3x=x%3例 a=3; d=func(); c=d+2;48v说明:l结合方向:自右向左l优先级: 14l左侧必须是变量,不能是常量或表达式l赋值表达式的值与变量值相等,且可嵌套l赋值转换规则:使赋值号右边表达式值自动转换成其左边变量的类型例 3=x-2*y; a+b=3;例 float f; int i; i=10; f=i;则 f=10.0例 int i; i=2.56; /结果i=2;例: a=b=c=5 a=(b=5) a=5+(

45、c=6) a=(b=4)+(c=6) a=(b=10)/(c=2)/表达式值为5,a,b,c值为5/ b=5;a=5/表达式值11,c=6,a=11/表达式值10,a=10,b=4,c=6/表达式值5,a=5,b=10,c=249v说明:l结合方向:自右向左l优先级: 12l左侧必须是变量,不能是常量或表达式l赋值表达式的值与变量值相等,且可嵌套l赋值转换规则:使赋值号右边表达式值自动转换成其左边变量的类型例: a=12; a+=a-=a*a例: int a=2; a%=4-1; a+=a*=a-=a*=3; /a=-264 等价于a=a+(a=a-(a*a)/a=0 等价于a=a+(a=a*

46、(a=a-(a=a*3)501.1.将整型数据赋给单、双精度变量时,数值不变将整型数据赋给单、双精度变量时,数值不变但以浮点数形式存储到变量中但以浮点数形式存储到变量中 如如: : 将将2323赋给赋给floatfloat变量,即执行变量,即执行2323,先,先将将2323转换成转换成23230000000000,再存储在中。,再存储在中。 将将2323赋给赋给doubledouble型变量,即执行型变量,即执行2323,系,系统将统将2323补足有效位数字为补足有效位数字为232300000000000000,00000000000000,然后以双精度浮点数形式存储到变量中。然后以双精度浮点

47、数形式存储到变量中。512.2.将一个将一个doubledouble型数据赋给型数据赋给floatfloat变量时,截取其变量时,截取其前面前面7 7位有效数字,存放到位有效数字,存放到floatfloat变量的存储单元变量的存储单元(4 4个字节)中。但应注意数值范围不能溢出。个字节)中。但应注意数值范围不能溢出。 如如: :float f;double d=123.456789e100; f=d;float f;double d=123.456789e100; f=d; 就出现溢出的错误。就出现溢出的错误。 如果将一个如果将一个floatfloat型数据赋给型数据赋给doubledoubl

48、e变量时,数值变量时,数值不变,有效位数扩展到不变,有效位数扩展到1616位,在内存中以位,在内存中以8 8个字节个字节存储存储. .523.3.字符型数据赋给整型变量时,由于字符只占字符型数据赋给整型变量时,由于字符只占1 1个字节,而整型变量为个字节,因此将字个字节,而整型变量为个字节,因此将字符数据(个二进位)放到整型变量存储单元符数据(个二进位)放到整型变量存储单元的低位中的低位中. .53第一种情况:第一种情况:低位对应、高位补零低位对应、高位补零 若所用系统将字符处理为无符若所用系统将字符处理为无符号字符类型,或程序已将字符变量号字符类型,或程序已将字符变量定义为定义为unsign

49、ed charunsigned char型,则将字型,则将字符的位放到整型变量低位,高符的位放到整型变量低位,高位补零。位补零。例如:例如:将字符将字符376赋给赋给int型变量型变量第二种情况:第二种情况:符号扩展符号扩展 若所用系统(如若所用系统(如Turbo C+Turbo C+)将字符处理为带符号(将字符处理为带符号(signed signed charchar)时,若字符最高位为,则整型变量高位补;若字时,若字符最高位为,则整型变量高位补;若字符最高位为,则高位全补。这称为符最高位为,则高位全补。这称为“符号扩展符号扩展”,这样,这样做的目的是使数值保持不变,如变量(字符做的目的是使

50、数值保持不变,如变量(字符376376)以整)以整数形式输出为,的值也是。数形式输出为,的值也是。544.4.将一个将一个intint、shortshort、longlong型数据赋给一个型数据赋给一个charchar型变型变量时,只将其低量时,只将其低8 8位原封不动地送到位原封不动地送到charchar型变量(即型变量(即截断)。截断)。例如:例如:int i=289;char c=a;c=i;c的值为33,如果用“%c”输出c,将得到字符“!” !的ASCII码为33。 赋值情况 :555. 将带符号的整型数据(int型)赋给long型变量时,要进行符号扩展,将整型数的16位送到long

51、型低16位中:如果int型数据为正值(符号位为),则long型变量的高16位补;如果int型变量为负值(符号位为),则long型变量的高16位补,以保持数值不改变。 反之,若将一个long型数据赋给一个int型变量,只将long型数据中低16位原封不动地送到整型变量(即截断)。 56例如:例如:int a;long b;a=b 赋值情况如下赋值情况如下 :如果65536(八进制数0200000),则赋值后值为。576.6.将将unsigned unsigned intint型数据赋给型数据赋给long long intint型变量时,不型变量时,不存在符号扩展问题,只需将高位补即可。存在符号扩

52、展问题,只需将高位补即可。将一个将一个unsignedunsigned类型数据赋给一个占字节数相同的非类型数据赋给一个占字节数相同的非unsignedunsigned型整型变量(例如:型整型变量(例如:unsigned unsigned intint -intint,unsigned long-longunsigned long-long,unsigned shortunsigned short-short-short),将),将unsignedunsigned型变量的内容原样送到非型变量的内容原样送到非unsignedunsigned型变量中,但如果数据范围超过相应整型的型变量中,但如果数据

53、范围超过相应整型的范围,则会出现数据错误。范围,则会出现数据错误。58逗号运算符和表达式v形式:表达式1,表达式2,表达式nv结合性:从左向右v优先级: 15v逗号表达式的值:等于表达式n的值v用途:常用于循环for语句中例 a=3*5,a*4 a=3*5,a*4,a+5例 x=(a=3,6*3) x=a=3,6*a例 a=1;b=2;c=3; printf(“%d,%d,%d”,a,b,c); printf(“%d,%d,%d”,(a,b,c),b,c); /a=15,表达式值60/a=15,表达式值20/赋值表达式,表达式值18,x=18/逗号表达式,表达式值18,x=3/1,2,3/3,

54、2,359逗号运算符和表达式v形式:表达式1,表达式2,表达式nv结合性:从左向右v优先级: 15v逗号表达式的值:等于表达式n的值v用途:常用于循环for语句中例:/*ch2_6.c*/#include main() int x,y=7; float z=4; x=(y=y+6,y/z); printf(x=%dn,x);运行结果:x=360关系运算符和表达式v关系运算符l种类: = !=l结合方向:自左向右l优先级别:=!=优先级6(高)优先级7(低)例 ca+b /c(a+b) ab!=c /(ab)!=c a=bc /a=(bc /a=(bc)l关系表达式的值:是逻辑值“真”或“假”,

55、用1和0表示例 int a=3,b=2,c=1,d,f; ab (ab)=c b+cb f=abc/表达式值1/表达式值1/表达式值0/d=1/f=061l关系运算注意:例 若a=0; b=0.5; x=0.3; 则 a=x278在C中是允许的, 值为0例 int i=1, j=7,a; a=i+(j%4!=0); 则a=2例 a0 结果为 A100 结果为1062l关系运算注意:例 注意区分“=”与“=” int a=0,b=1; if(a=b) printf(“a equal to b”); else printf(“a not equal to b”);例 应避免对实数作相等或不等的判断

56、如 1.0/3.0*3.0=1.0 结果为可改写为:fabs(1.0/3.0*3.0-1.0)1e-6063ab!a!ba&ba|b真假真假假假真真逻辑运算符和表达式v逻辑运算符l种类: ! & |l逻辑运算真值表lC语言中,运算量: 0表示“假”, 非0表示“真”, 运算结果: 0表示“假”, 1表示“真”,真假假假假假真真假假真真真假真真64! (2)& (11)| (12)高低例 a=x & xb&xy a=b|x=y !a|abl优先级:l结合方向:! :从右向左& :从左向右| :从左向右/ (a=x) & (xb)&(xy)/(a=b)|(x=y)/(!a)|(ab)65! (2)

57、& (11)| (12)高低l优先级:l结合方向:! :从右向左& :从左向右| :从左向右例 a=4;b=5; !a a&b a|b !a|b 4&0|2 53&2|84-!0 c&d值为1值为0值为1值为1值为1值为1/(53)&2|(8(4-(!0) 值为166! (2)& (11)| (12)高低l优先级:l结合方向:! :从右向左& :从左向右| :从左向右l短路特性:逻辑表达式求解时,并非所有的逻辑运算符都被执行,只是在必须执行下一个逻辑运算符才能求出表达式的解时,才执行该运算符例 a&b&c /只在a为真时,才判别b的值; 只在a、b都为真时,才判别 c的值例 a|b|c /只在

58、a为假时,才判别b的值; 只在a、b都为假时,才判别 c的值例 a=1;b=2;c=3;d=4;m=1;n=1; (m=ab)&(n=cd)/结果m=0,n=167条件运算符与表达式v一般形式: expr1 ? expr2 : expr3v执行过程v功能:相当于条件语句,但不能取代一般if语句例 if (ab) printf(“%d”,a); else printf(“%d”,b);printf(“%d”,ab?a:b);例 求 a+|b| printf(“a+|b|=%dn”,b0?a+b:a-b);expr1取expr2值取expr3值非0=0例 (a=b)?Y:N (x%2=1)?1:0 (x=0)?x:-x (c=a & c0?1:(xb?a:cd?c:d ab?a:(cd?c:d)vexpr1、expr2、expr3类型可不同,表达式值取较高的类型例 x?a:b /x=0,表达式值为b; x0,表达式值为a xy?1:1.5 /xy ,值为1.0; xy ,值为1.568

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 资格认证/考试 > 自考

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号