版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、1第三章 数据类型、运算符与表达式v各种进制之间的转换l二进制、八进制、十六进制转换成十进制u方法:按权相加10012345259212120212121111011)()(例10012894868381136)()(例1001231679781610162161516121)()(例AF2v各种进制之间的转换(整数)l二进制、八进制、十六进制转换成十进制u方法:按权相加l十进制转换成二进制、八进制、十六进制u原理:的余数是2)2.22(222.22).(00012110011112011NaaaaaaaaaaaaaNnnnnnnnnnnu方法:连续除以基,从低到高记录余数,直至商为0例 把十
2、进制数59转换成二进制数5922921427232120(59)10=(111011)21101111 1 1 0 1 1余余余余余余例 把十进制数159转换成八进制数1598198280(159)10=(237)82 3 7 余 7余 3余 2例 把十进制数459转换成十六进制数4591628161160(459)10=(1CB)161 C B 余11余12余 13l二进制与八进制之间的转换u二进制转换成八进制:从右向左,每3位一组(不足3位左补0),转换成八进制u八进制转换成二进制:用3位二进制数代替每一位八进制数例 (1101001)2=(001,101,001)2=(151)8例 (2
3、46)8=(010,100,110)2=(10100110)2000 0001 1010 2011 3100 4101 5110 6111 74l二进制与十六进制之间的转换u二进制转换成十六进制:从右向左,每4位一组(不足4位左补0),转换成十六进制u十六进制转换成二进制:用4位二进制数代替每一位十六进制数例 (11010101111101)2=(0011,0101,0111,1101)2=(357D)16例 (4B9E)16=(0100,1011,1001,1110)2=(100101110011110)20000 00001 10010 20011 30100 40101 50110 60
4、111 71000 81001 91010 A1011 B1100 C1101 D1110 E1111 F5字节和位v内存以字节为单元组成v每个字节有一个地址v一个字节一般由8个二进制位组成v每个二进位的值是0或101234567012345678910.6数值的表示方法原码、反码和补码v原码:最高位为符号位,其余各位为数值本身的绝对值v反码:l正数:反码与原码相同l负数:符号位为1,其余位对原码取反v补码:l正数:原码、反码、补码相同l负数:最高位为1,其余位为原码取反,再对整个数加13126912457810119-5=49+7=16=(4)127原码反码补码+70000011100000
5、11100000111-7100001111111100011111001+0000000000000000000000000-0100000001111111100000000数的范围0111111111111111(-127+127)0111111110000000(-127+127)0111111110000000(-128+127)(用一字节表示数)v负数补码转换成十进制数:最高位不动,其余位取反加1例 补码:11111001 取反:10000110 加1: 10000111=-783.1 数据类型数据类型总表C数据类型基本类型构造类型指针类型空类型void定义类型typedef字符类
6、型char枚举类型enum整 型实型单精度型float双精度型double数组结构体struct共用体union短整型short长整型long整型int数据类型决定:1. 数据占内存字节数2. 数据取值范围3. 其上可进行的操作9基本数据类型类型符号关键字数的表示范围所占位数整型字符型实型有无(signed)int16-3276832767(signed)short16-3276832767(signed)long32-2147483648214748364716unsigned int0655353204294967295unsigned longunsigned short16065535
7、有float323.4e-383.4e38有double641.7e-3081.7e308有char8-128127无unsigned char80255说明:数据类型所占字节数随机器硬件不同而不同,上表以IBM PC机为例:103.2 常量与变量标识符v定义:用来标识变量、常量、函数等的字符序列v组成:l只能由字母、数字、下划线组成,且第一个字母必须是字母或下划线l大小写敏感l不能使用关键字v长度:最长32个字符v命名原则:l见名知意l不宜混淆 如l与I, o与0例:判断下列标识符号合法性sum Sum M.D.John day Date 3days student_name #33 lot
8、us_1_2_3 char ab _above $123M.D.John3days#33char$123ab11u一般用大写字母u是宏定义预处理命令,不是C语句如 #define PRICE 30常量v定义:程序运行时其值不能改变的量(即常数)v分类:l符号常量:用标识符代表常量u定义格式: #define 符号常量 常量例 符号常量举例(ch2_1.c)#define PRICE 30main() int num,total; num=10; total=num*PRICE; printf(total=%d,total);运行结果:total=300 程序中用#define命令行定义PRIC
9、E代表常量30,此后凡在本文件中出现的PRICE都代表30,可以和常量一样进行运算如再用赋值语句给PRICE赋值是错的 PRICE=40;/* 错误,不能给符号常量赋值3.2 常量与变量12变量变量变量代表内存中具有特定属性的一个存储单元,它变量代表内存中具有特定属性的一个存储单元,它用来存放数据,这就是变量的值。用来存放数据,这就是变量的值。变量名实际上是一个以一个名字对应代表一个地址,变量名实际上是一个以一个名字对应代表一个地址,在对程序编译连接时由编译系统给每一个变量名分在对程序编译连接时由编译系统给每一个变量名分配对应的内存地址。从变量中取值,实际上是通过配对应的内存地址。从变量中取值
10、,实际上是通过变量名找到相应的内存地址,从该存储单元中读取变量名找到相应的内存地址,从该存储单元中读取数据。数据。13编译程序根据变量定义为其分配指定字节的内存单元.地址int a=1, b=-3,c;abc2字节2字节2字节地址地址.内存1-3随机数变量v概念:其值可以改变的量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; in
11、t 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 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;
12、 data=(a+b)*1.2; printf(“data=%fn”,data);143.2 常量与变量标识符v定义:用来标识变量、常量、函数等的字符序列v组成:l只能由字母、数字、下划线组成,且第一个字母必须是字母或下划线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$123ab建议变量名的长度最好不建议变量名的长
13、度最好不要超过要超过8 8个字符个字符. .15&整型常量(整常数)v三种形式:l十进制整数:由数字09和正负号表示.如 123,-456,0l八进制整数:由数字0开头,后跟数字07表示.如0123,011l十六进制整数:由0 x开头,后跟09,af,AF表示. 如0 x123,0 xff例 12 与 12L例 30000 为int型 65536 为long int 型v整型常量的类型l根据其值所在范围确定其数据类型l在整常量后加字母l或L,认为它是long int 型常量问题:0123 = ( )100 x123 = ( )100 xff = ( )1083291255问题:0123
14、 = ( )100 x123 = ( )100 xff = ( )10163.3.2 整型变量整型变量 (1)(1)整型数据在内存中的存放形式整型数据在内存中的存放形式 数据在内存中是以二进制形式存放的。数据在内存中是以二进制形式存放的。 如如: : int i; / int 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为一个
15、整型变量在内存中分配为一个整型变量在内存中分配2 2个字节的存储单元个字节的存储单元( (不同的编译系不同的编译系统为整型数据分配的字节数是不相同的,统为整型数据分配的字节数是不相同的,VC+ 6.0VC+ 6.0则分配则分配4 4个字个字节节) )。 数值是以补码数值是以补码(complement) (complement) 表示的。表示的。 17(2)(2)整型变量的分类整型变量的分类共六种共六种有符号基本整型有符号短整型有符号长整型无符号基本整型无符号短整型无符号长整型(signed)int (signed)short (int )(signed) long (int)unsigned
16、intunsigned short (int)unsigned long (int) 注意:注意:括号表示其中的内容是可选的括号表示其中的内容是可选的. .18整数类型的有关数据:整数类型的有关数据: 类型类型 类型说明符类型说明符 长度长度 数的范围数的范围 基本型基本型 int 2 int 2字节字节 -32768 -327683276732767 短整型短整型 short 2short 2字节字节 -2 -215152 21515-1 -1 长整型长整型 long 4 long 4字节字节 -2 -231312 23131-1-1 无符号整型无符号整型 unsigned 2 unsign
17、ed 2字节字节 0 06553565535 无符号短整型无符号短整型 unsigned short unsigned short 2 2字节字节 0 06553565535 无符号长整型无符号长整型 unsigned long unsigned long 4 4字节字节 0 0(2 23232-1-1)19例如:整数例如:整数1313在内存中实际存放的情况:在内存中实际存放的情况:20例3.2 整型变量的定义与使用#include #include void main()() int a,b,c,d; /*指定、为整指定、为整型变量型变量* unsigned ; *指定为无符号整型变指定为无
18、符号整型变量量* 12;-24;10; ; printf(,);,); 可以看到不同种类的整型数据可以进行算术运算可以看到不同种类的整型数据可以进行算术运算 运行结果:运行结果: , 21例3.3 整型数据的溢出#include #include void main()void main()int a,b; int a,b; a=32767; a=32767; b=a+1; b=a+1; printf(“%d,%dn”,a,b); printf(“%d,%dn”,a,b); 数值是以补码表示的。一个整型变量只能容纳-3276832767范围内的数,无法表示大于32767或小于-32768的数。
19、遇此情况就发生“溢出”。运行结果:运行结果: 32767,-3276832767,-32768223.3.3 3.3.3 整型常量的类型整型常量的类型 (1)(1)一个整数,如果其值在一个整数,如果其值在-32768-32768+32767+32767范围内,认为它是范围内,认为它是intint型,它可以赋值给型,它可以赋值给intint型和型和long intlong int型变量。型变量。 (2) (2) 一个整数,如果其值超过了上述范围,而在一个整数,如果其值超过了上述范围,而在- -21474836372147483637+2147483647+2147483647范围内,则认为它是为
20、长整型。范围内,则认为它是为长整型。可以将它赋值给一个可以将它赋值给一个long intlong int型变量。型变量。 (3) (3) 如果所用的如果所用的C C版本(如版本(如Turbo CTurbo C)分配给)分配给short intshort int与与intint型数据在内存中占据的长度相同,则它的表数范围与型数据在内存中占据的长度相同,则它的表数范围与intint型型相同。因此一个相同。因此一个intint型的常量同时也是一个型的常量同时也是一个short intshort int型常量,型常量,可以赋给可以赋给intint型或型或short intshort int型变量。型变
21、量。 23(4) (4) 一个整常量后面加一个字母一个整常量后面加一个字母u u或或U U,认为是,认为是unsigned unsigned intint型,如型,如12345u12345u,在内存中按,在内存中按unsigned intunsigned int规定的规定的方式存放方式存放( (存储单元中最高位不作为符号位,而用来存储单元中最高位不作为符号位,而用来存储数据存储数据) )。如果写成。如果写成-12345u-12345u,则先将,则先将-12345-12345转换转换成其补码成其补码5319153191,然后按无符号数存储。,然后按无符号数存储。(5) (5) 在一个整常量后面加
22、一个字母在一个整常量后面加一个字母l l或或L L,则认为是,则认为是long long intint型常量。型常量。 例如:例如: 123l.432L.0L123l.432L.0L 用于函数调用中。用于函数调用中。如果函数的形参为如果函数的形参为long intlong int型,则要求实参也为型,则要求实参也为long intlong int型。型。24&实型常量(实数或浮点数)v表示形式:l十进制数形式:(必须有小数点) 如0.123, .123, 123.0, 0.0, 123.l指数形式:(e或E之前必须有数字;指数必须为整数)如12.3e3 ,123E2, 1.23e4 ,
23、 e-5 , 1.2E-3.5 v实型常量的类型l默认double型l在实型常量后加字母f或F,认为它是float 型C C编译系统将浮点型常量作为双精度来编译系统将浮点型常量作为双精度来处理。处理。 例如例如:f = 2.45678 f = 2.45678 * * 4523.65 4523.65 系统先把系统先把2.456782.45678和和4523.654523.65作为双作为双精度数,然后进行相乘的运算,得到的精度数,然后进行相乘的运算,得到的乘也是一个双精度数。最后取其前乘也是一个双精度数。最后取其前7 7位位赋给浮点型变量赋给浮点型变量f f。如是在数的后面加。如是在数的后面加字母
24、字母f f或或F F(如(如1.65f, 654.87F1.65f, 654.87F),这样),这样编译系统就会把它们按单精度(编译系统就会把它们按单精度(3232位)位)处理处理. .25规范化的指数形式:规范化的指数形式: 在字母在字母e e(或(或E E)之前的小数部分中,小数点左边)之前的小数部分中,小数点左边应有一位(且只能有一位)非零的数字应有一位(且只能有一位)非零的数字. . 例如例如: : 123.456123.456可以表示为:可以表示为: 123.456e0, 12.3456e1, 1.23456e2, 123.456e0, 12.3456e1, 1.23456e2, 0
25、.123456e3, 0.0123456e4, 0.00123456e0.123456e3, 0.0123456e4, 0.00123456e 其中的其中的1.23456e31.23456e3称为称为“规范化的指数形式规范化的指数形式”。263.4.2 浮点型变量浮点型变量(1)(1)浮点型数据在内存中的存放形式浮点型数据在内存中的存放形式 一个浮点型数据一般在内存中占一个浮点型数据一般在内存中占4 4个字节个字节(32(32位位) )。与整。与整型数据的存储方式不同,浮点型数据是按照指数形式存型数据的存储方式不同,浮点型数据是按照指数形式存储的。系统把一个浮点型数据分成小数部分和指数部分,储
26、的。系统把一个浮点型数据分成小数部分和指数部分,分别存放。指数部分采用规范化的指数形式。分别存放。指数部分采用规范化的指数形式。27类型类型 位数位数 数的范围数的范围 有效数字有效数字float 32float 32 10 10-37 -37 101038 38 6 67 7 位位doubledouble型型 64 64 10 10-307-3071010308308 15 151616位位long double 128 10long double 128 10-4931-493110104932 4932 18181919位位 3.4 浮点型数据浮点型数据(2) (2) 浮点型变量的分类浮
27、点型变量的分类 浮点型变量分为单精度(浮点型变量分为单精度(floatfloat型)、双精度(型)、双精度(doubledouble型)和长双精度型(型)和长双精度型(long doublelong double)三类形式。)三类形式。例 float a;a=111111.111; /* a=111111.1*/double b;b=111111.111; /* b=111111.111*/28例3.4 浮点型数据的舍入误差#include #include void main()void main()float a,b;float a,b; a = 123456.789e5; a = 123
28、456.789e5; b = a + 20 ; b = a + 20 ; printf(“%fn”,b); printf(“%fn”,b); 一个浮点型变量只能保证的有效数字是7位有效数字,后面的数字是无意义的,并不准确地表示该数。应当避免将一个很大的数和一个很小的数直接相加或相减,否则就会“丢失”小的数运行结果:运行结果: 123456.789e5123456.789e529&字符常量v定义:用单引号括起来的单个普通字符或转义字符. v字符常量的值:该字符的ASCII码值转义字符及其含义:转义字符含义nvradddtbf“xhh转义字符含义换行垂直制表回车响铃单引号3位8进制数代表的
29、字符水平制表退格换页反斜线双引号2位16进制数代表的字符如 101 -A 012 -n 376 - x61 -a 60 -0 483 -()例:A-101-x41-65如 A65, a97, 048 , n10如 a A ? 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
30、 ProgramTurbo C例 main() printf(“Yb=n”); 运行结果:屏幕显示:=打印机输出:30 3.5 3.5 字符型数据字符型数据 3.5.23.5.2字符变量字符变量字符型变量用来存放字符常量,注意只能字符型变量用来存放字符常量,注意只能放一个字符。放一个字符。字符变量的定义形式如下:字符变量的定义形式如下:char c1,c2;char c1,c2;可以用下面语句对可以用下面语句对c1,c2c1,c2赋值:赋值: c1c1aa;c2c2 b b ;一个字符变量在内存中占一个字节。一个字符变量在内存中占一个字节。 31 3.5 字符型数据字符型数据 3.5.3 字符
31、数据在内存中的存储形式及其使用方法字符数据在内存中的存储形式及其使用方法一个字符常量存放到一个字符变量中,实际上并不是把一个字符常量存放到一个字符变量中,实际上并不是把该字符的字型放到内存中去,而是将该字符的相应的该字符的字型放到内存中去,而是将该字符的相应的ASCIIASCII代码放到存储单元中。这样使字符型数据和整型数代码放到存储单元中。这样使字符型数据和整型数据之间可以通用。据之间可以通用。注意注意: : 一个字符数据一个字符数据既可以以字既可以以字符形式输出,符形式输出,也可以以整也可以以整数形式输出。数形式输出。32例3.6 向字符变量赋以整数。 #include #include
32、void main()void main() char c1,c2; char c1,c2; c1=97; c1=97; c2=98; c2=98; printf(“%c %cn”,c1,c2); printf(“%c %cn”,c1,c2); printf(“%d %dn”,c1,c2); printf(“%d %dn”,c1,c2); 在第和第4行中,将整数97和98分别赋给c1和c2,它的作用相当于以下两个赋值语句:c1;c2; 因为a和b的ASCII码为97和98 运行结果:运行结果: 97 9897 9833例3.7 大小写字母的转换 #include #include void m
33、ain()void main() char c1,c2 char c1,c2; c1=a;c1=a; c2=b; c2=b;c1=c1-32;c1=c1-32;c2=c2-32;c2=c2-32; printf(“ printf(“c c cc,c1,c2c1,c2);); 程序的作用是将两个小写字母a和b转换成大写字母A和B。从代码表中可以看到每一个小写字母比它相应的大写字母的ASCII码大32。语言允许字符数据与整数直接进行算术运算。 运行结果:运行结果: 34 有些系统(如Turbo C)将字符变量定义为signed char型。其存储单元中的最高位作为符号位,它的取值范围是-12812
34、7。如果在字符变量中存放一个ASCII码为0127间的字符,由于字节中最高位为0,因此用%d输出字符变量时,输出的是一个正整数。如果在字符变量中存放一个ASCII码为128255间的字符,由于在字节中最高位为1,用%d格式符输出时,就会得到一个负整数。 35v字符常量与字符串常量不同&字符串常量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、字符串常量赋给串常量赋给一个字符变一个字符变量。量。36 3.6 变量赋初值 (1)(1)语言允许在定义变量的同时使变量初始化语言允许在定义变量的同时使变量初始化如如: : int a=3; / int a=3; / 指定为整型变量,初值为指定为整型变量,初值为 float f=3.56; / float f=3.56; / 指定为浮点型变量,初值为指定为浮点型变量,初值为 .56 .56 char c= a; / char c= a; / 指定为字符变量,初值为指定为字符变量,初值为a a 37 3.6 变量赋初值变量赋初值 (2)(2)可以使被定义的变量的一部分赋初值。可以使被定义的变量的
36、一部分赋初值。 如如: : int a,b,c=5int a,b,c=5; 表示指定、为整型变量,但表示指定、为整型变量,但只对初始化,只对初始化,c c的初值为的初值为(3)(3)如果对几个变量赋以同一个初值,如果对几个变量赋以同一个初值, 应写成:应写成:int a=3,b=3,c=3; int a=3,b=3,c=3; 表示、的初值都是表示、的初值都是。 不能写成不能写成 int a=b=c=3; int a=b=c=3; 注意:注意:初始化不是在编译阶段完成的而是在程序运行时执行初始化不是在编译阶段完成的而是在程序运行时执行本函数时赋初值的,相当于有一个赋值语句。本函数时赋初值的,相当
37、于有一个赋值语句。 382.3不同类型数据间的转换隐式转换v什么情况下发生l运算转换-不同类型数据混合运算时l赋值转换-把一个值赋给与其类型不同的变量时l输出转换-输出时转换成指定的输出格式l函数调用转换-实参与形参类型不一致时转换v运算转换规则:不同类型数据运算时先自动转换成同一类型39doublefloatlongunsignedintchar,short低高说明:必定的转换运算对象类型不同时转换例 char ch; int i; float f; double d;ch/i + f*d - (f+i)intintdoubledoubledoubledoubledoubledoublein
38、tintdoubledoubledoubledoubledoubledouble10+a +i*f - d/l例 int i; float f; double d; long l;40显式转换(强制转换)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精度损失问题较高类型向较低类型转换时可能发生412
39、.4 运算符和表达式C运运算算符符算术运算符:(算术运算符:(+ - + - * * / % + - / % + -)关系运算符:(关系运算符:( = != = !=)逻辑运算符:(!逻辑运算符:(! & |& |)位运算符位运算符 :(:( | & | &)赋值运算符:(赋值运算符:(= = 及其扩展)及其扩展)条件运算符:(条件运算符:(?:?:)逗号运算符:(逗号运算符:(, ,)指针运算符:(指针运算符:(* * & &)求字节数求字节数 :(:(sizeofsizeof)强制类型转换:(类型)强制类型转换:(类型)分量运算符:(分量运算
40、符:(. -. -)下标运算符:(下标运算符:()其它其它 :(:(( ) -( ) -)42算术运算符和表达式v基本算术运算符: + - * / %l结合方向:从左向右l优先级: - -* / % - + - (2) (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 ()43v自增、自减运算符+ -l作用:使变量值
41、加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); 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=444v自增、自减运算符+ -l作用:使变量值加1或减1l种类:u前置 +i, -i (先执行i+1或i-1,再使用i值)u后置 i+,i- (先使用i值,再执行i+1或i-1)l说明:
42、u+ - 不能用于常量和表达式,如5+,(a+b)+u+ -结合方向: 自右向左u优先级:- + - -* / % -+ - (2) (3) (4)例 -i+ -(i+) i=3; printf(“%d”,-i+); /-3 例 j+k; (j+)+k;例 -i+ i=3; printf(“%d”,-i+); 45(5) (5) 有关表达式使用中的问题说明有关表达式使用中的问题说明 ANSI C并没有具体规定表达式中的子表达式的求值顺序,允许各编译系统自己安排。 例如:对表达式 a = f1( )+f2( ) 并不是所有的编译系统都先调用f1( ), 然后调用f2( )。在有的情况下结果可能不
43、同。有时会出现一些令人容易搞混的问题,因此务必要小心谨慎。 46语言中有的运算符为一个字符,有的运算符由两个字符组成 ,为避免误解,最好采取大家都能理解的写法。 例如:不要写成i+j的形式,而应写成 (i+)+j的形式.47在调用函数时,实参数的求值顺序,标准并无统一规定。例如:例如:的初值为,如果有下面的函数调用: printf(,i+) 在有的系统中,从左至右求值,输出“,”。在多数系统中对函数参数的求值顺序是自右而左, 函数输出的是“,”。以上这种写法不宜提倡, 最好改写成 j = i+;j = i+; printf(%d printf(%d, %d%d, j j,i)i)48赋值运算符
44、和表达式v简单赋值运算符l符号: =l格式: 变量标识符=表达式l作用:将一个数据(常量或表达式)赋给一个变量v复合赋值运算符l种类:+= -= *= /= %= = = &= = |=l含义: exp1 op= exp2exp1 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;49v说明:l结合方向:自右向左l优先级: 14l左侧必须是变量,不能是常量或表达式l赋值表达式的值与变量值相等,且可嵌套l赋值转换规则:使赋值号右边表达
45、式值自动转换成其左边变量的类型例 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+(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=250v说明:l结合方向:自右向左l优先级: 12l左侧必须是变量,不能是常量或表达式l赋值表达式的值与变量值相等,且可嵌套l赋值转换规则:使赋
46、值号右边表达式值自动转换成其左边变量的类型例: 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*(a=a-(a=a*3)511.1.将整型数据赋给单、双精度变量时,数值不变将整型数据赋给单、双精度变量时,数值不变但以浮点数形式存储到变量中但以浮点数形式存储到变量中 如如: : 将将2323赋给赋给floatfloat变量,即执行变量,即执行2323,先,先将将2323转换成转换成23230000000000,再存储在中。,再存储在中。 将将2323赋给赋给do
47、ubledouble型变量,即执行型变量,即执行2323,系,系统将统将2323补足有效位数字为补足有效位数字为232300000000000000,00000000000000,然后以双精度浮点数形式存储到变量中。然后以双精度浮点数形式存储到变量中。522.2.将一个将一个doubledouble型数据赋给型数据赋给floatfloat变量时,截取其变量时,截取其前面前面7 7位有效数字,存放到位有效数字,存放到floatfloat变量的存储单元(变量的存储单元(4 4个字节)中。但应注意数值范围不能溢出。个字节)中。但应注意数值范围不能溢出。 如如: :float f;double d=1
48、23.456789e100; float f;double d=123.456789e100; f=d;f=d; 就出现溢出的错误。就出现溢出的错误。 如果将一个如果将一个floatfloat型数据赋给型数据赋给doubledouble变量时,数值变量时,数值不变,有效位数扩展到不变,有效位数扩展到1616位,在内存中以位,在内存中以8 8个字节个字节存储存储. .533.3.字符型数据赋给整型变量时,由于字符只占字符型数据赋给整型变量时,由于字符只占1 1个字节,而整型变量为个字节,因此将字个字节,而整型变量为个字节,因此将字符数据(个二进位)放到整型变量存储单元符数据(个二进位)放到整型变
49、量存储单元的低位中的低位中. .54第一种情况:第一种情况:低位对应、高位补零低位对应、高位补零 若所用系统将字符处理为无符若所用系统将字符处理为无符号字符类型,或程序已将字符变量号字符类型,或程序已将字符变量定义为定义为unsigned charunsigned char型,则将字型,则将字符的位放到整型变量低位,高符的位放到整型变量低位,高位补零。位补零。例如:例如:将字符将字符376赋给赋给int型变量型变量第二种情况:第二种情况:符号扩展符号扩展 若所用系统(如若所用系统(如Turbo C+Turbo C+)将字符处理为带符号()将字符处理为带符号(signed signed char
50、char)时,若字符最高位为,则整型变量高位补;若字)时,若字符最高位为,则整型变量高位补;若字符最高位为,则高位全补。这称为符最高位为,则高位全补。这称为“符号扩展符号扩展”,这样,这样做的目的是使数值保持不变,如变量(字符做的目的是使数值保持不变,如变量(字符376376)以整)以整数形式输出为,的值也是。数形式输出为,的值也是。554.4.将一个将一个intint、shortshort、longlong型数据赋给一个型数据赋给一个charchar型变型变量时,只将其低量时,只将其低8 8位原封不动地送到位原封不动地送到charchar型变量(即型变量(即截断)。截断)。例如:例如:int
51、 i=289;char c=a;c=i;c的值为33,如果用“%c”输出c,将得到字符“!” !的ASCII码为33。 赋值情况 :565. 将带符号的整型数据(int型)赋给long型变量时,要进行符号扩展,将整型数的16位送到long型低16位中:如果int型数据为正值(符号位为),则long型变量的高16位补;如果int型变量为负值(符号位为),则long型变量的高16位补,以保持数值不改变。 反之,若将一个long型数据赋给一个int型变量,只将long型数据中低16位原封不动地送到整型变量(即截断)。 57例如:例如:int a;long b;a=b 赋值情况如下赋值情况如下 :如果
52、65536(八进制数0200000),则赋值后值为。586.6.将将unsigned intunsigned int型数据赋给型数据赋给long intlong int型变量时,不型变量时,不存在符号扩展问题,只需将高位补即可。存在符号扩展问题,只需将高位补即可。将一个将一个unsignedunsigned类型数据赋给一个占字节数相同的非类型数据赋给一个占字节数相同的非unsignedunsigned型整型变量(例如:型整型变量(例如:unsigned int unsigned int -int-int,unsigned long-longunsigned long-long,unsigned
53、 shortunsigned short-short-short),将),将unsignedunsigned型变量的内容原样送到非型变量的内容原样送到非unsignedunsigned型变量中,但如果数据范围超过相应整型的型变量中,但如果数据范围超过相应整型的范围,则会出现数据错误。范围,则会出现数据错误。59逗号运算符和表达式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,表达式值
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年物流行业管理层劳动合同模板
- 2024年船舶租赁协议样本
- 2024民宿酒店特色餐饮服务承包经营合同范本3篇
- 2024年电器产品代理销售合同3篇
- 2024年餐饮业竞业禁止保密合同版B版
- 2024年货物运输协议版B版
- 2024年电子商务企业区块链技术应用合同
- 2024年行政中心5号楼停车场管理与收费服务合同3篇
- 2024年美容院电子商务平台建设与运营合同
- 2024年特定建筑能效提升工程协议版B版
- MOOC 天气学-国防科技大学 中国大学慕课答案
- 小学教育教学现场会活动方案
- 文言文阅读-【中职】广东省近十年(2014-2023)中职春季高考语文真题汇编(解析版)
- 凸透镜和凹透镜课件
- 欧洲监控行业分析
- NB/T 11266-2023火储联合调频项目后评估导则
- 上海中心幕墙施工方案
- 某中央空调机房拆除施工方案
- 2024年江苏南京大数据集团有限公司招聘笔试参考题库含答案解析
- 医疗护理安全警示教育讲解
- 园林绿地冬季防火措施(参考范本)
评论
0/150
提交评论