C语言程序设计ppt课件_第1页
C语言程序设计ppt课件_第2页
C语言程序设计ppt课件_第3页
C语言程序设计ppt课件_第4页
C语言程序设计ppt课件_第5页
已阅读5页,还剩66页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、Chap 6 数据类型和表达式数据类型和表达式 6.1 数据的存储和基本数据类型数据的存储和基本数据类型 6.2 常量和变量常量和变量 6.3 数据的输入和输出数据的输入和输出6.4 类型转换类型转换6.5 表达式表达式1本章要点本章要点nC语言的基本数据类型有哪些?语言的基本数据类型有哪些?n各种基本数据类型的常量和变量是怎样各种基本数据类型的常量和变量是怎样定义的?定义的?nC语言有哪些表达式?语言有哪些表达式? n各种表达式的求解规则是什么?各种表达式的求解规则是什么?2数据类型和表达式数据类型和表达式n数据类型数据类型基本数据类型基本数据类型n整型整型intn实型(浮点型)实型(浮点型

2、)float doublen字符型字符型char构造数据类型构造数据类型数组、结构、联合、枚举数组、结构、联合、枚举指针类型指针类型空类型空类型n运算:对数据的操作运算:对数据的操作运算符数据运算符数据 表达式表达式36.1 数数据的存储和基本数据类型据的存储和基本数据类型6.1.1 数据的存储数据的存储整型、实型、字符型数据的存储整型、实型、字符型数据的存储6.1.2 基本数据类型基本数据类型整型、实型、字符型整型、实型、字符型46.1.1 数据的存储整型数据数据的存储整型数据设整数在内存中用设整数在内存中用2个字节存储个字节存储1 000 0001 1000 00010 000 0001

3、1000 0001符号位符号位1:负数:负数0:正数:正数5数值的表示方法原码数值的表示方法原码 反码反码 补码补码n正数正数的原码、反码和补码相同的原码、反码和补码相同1 的补码的补码 0 000 0000 0000 000132767 的补码的补码 0 111 1111 1111 1111(215-1,2个字节的存储单元能表示的最大正数个字节的存储单元能表示的最大正数)n负数负数的原码、反码和补码不同的原码、反码和补码不同 -1原码原码 1 000 0000 0000 0001 反码反码 1 111 1111 1111 1110 原码取反原码取反补码补码 1 111 1111 1111 1

4、111 反码反码16原码原码 反码反码 补码补码32767n补码补码 0 111 1111 1111 1111-32767n原码原码 1 111 1111 1111 1111n反码反码 1 000 0000 0000 0000 原码取反原码取反n补码补码 1 000 0000 0000 0001 反码反码1-32768 = -32767-1n补码补码 1 000 0000 0000 0000(2个字节的存储单元能表示的最小负数个字节的存储单元能表示的最小负数)7 -32768 -1 0 1 32767 32767 0111 1111 1111 1111 1 0000 0000 0000 000

5、1 0 0000 0000 0000 0000 -1 1111 1111 1111 1111 -2 1111 1111 1111 1110 -32767 1000 0000 0000 0001 -32768 1000 0000 0000 000032767 + 1 = 32768 ?1000 0000 0000 000 = -32768-32768 - 1 = -32769 ?0111 1111 1111 1111 = 327678实型和字符型数据的存储实型和字符型数据的存储n实型数据的存储实型数据的存储-e+02符号位符号位 阶码阶码 尾数尾数n字符型数据的存储字符型数据的存储一个字节存储一

6、个字节存储ASCII码码95.1.2 基本基本数据类型数据类型n整型整型有符号整型有符号整型 无符号整型无符号整型 数据长度数据长度int unsigned int 16或或32位位short int unsigned short int 16位位long int unsigned long int 32位位n字符型字符型char 8位位n实型(浮点型)实型(浮点型)单精度浮点型单精度浮点型 float 32位位双精度浮点型双精度浮点型 double 64位位10基本基本数据类型数据类型整型整型扩展的整数类型:扩展的整数类型:short long unsigned int有符号整型有符号整型

7、无符号整型无符号整型 数据长度数据长度int unsigned int 16或或32位位short int unsigned short int 16位位long int unsigned long int 32位位有符号有符号 short 1 000 0000 0000 0000 -32768 -2150 111 1111 1111 1111 32767 215-1无符号无符号 unsigned short0000 0000 0000 0000 01111 1111 1111 1111 65535 216-111整数类型的取值范围整数类型的取值范围int 32位位 -2147483648 2

8、147483647 -231 231-1short int 16位位 -32768 32767 -215 215-1long int 32位位 -2147483648 2147483647 -231 231-1unsigned int 32位位 0 4294967295 0 232-1unsigned short int 16位位 0 65535 0 216-1unsigned long int 32位位 0 4294967295 0 232-112基本基本数据类型数据类型字符型字符型n字符具有数值特征字符具有数值特征A 65 0100 0001 n整型变量和字符变量的定义和赋值可以互整型变量

9、和字符变量的定义和赋值可以互换换 【 ASCII码码范围】范围】 char c; c = A; 或或 c = 65; int i; i = 65; 或或 i = A;13基本基本数据类型数据类型实型实型实型(浮点型)数据实型(浮点型)数据n单精度浮点型单精度浮点型 floatn双精度浮点型双精度浮点型 double 存储存储 数据精度数据精度 取值范围取值范围 (有效数字有效数字)float 4字节字节 七七/八八位位 (10-38 1038)double 8字节字节 十六十六位位 (10308 10308 )14数据精度和取值范围数据精度和取值范围n数据精度数据精度 与与 取值范围取值范围是

10、两个不同的概念:是两个不同的概念:float x = 1234567.89;虽在取值范围内,但无法精确表达。虽在取值范围内,但无法精确表达。 float y = 1.2e55;y 的精度要求不高,但超出取值范围。的精度要求不高,但超出取值范围。n并不是所有的实数都能在计算机中精确表示并不是所有的实数都能在计算机中精确表示n 实型常量的类型都是实型常量的类型都是double156.2.1 常量常量符号常量符号常量整型常量、实型常量、字符型常量整型常量、实型常量、字符型常量6.2.2 变量变量 变量的定义和使用变量的定义和使用 6.2 常量和变量常量和变量166.2.1 常量常量常量的类型通常由书

11、写格式决定常量的类型通常由书写格式决定123 (整型)整型)4.56 (实型实型) A (字符型字符型)符号常量符号常量:用一个标识符代表一个常量:用一个标识符代表一个常量 :PI :EPS17例例5-1 求球的表面积和体积求球的表面积和体积# include # define PI int main(void) double r, s, v; printf(“Enter r: ); scanf(%lf, &r); s = 4.0 * PI * r * r ; v = 4.0 / 3.0 * PI * r * r * r ; printf(s=%f, v=%fn, s, v); return

12、0;加分号加分号? ?通常用大写字母通常用大写字母18符号常量的优点符号常量的优点# include int main(void) double r, s, v; scanf(%lf, &r); *r*r* ; v =*r*r*r* ; . return 0;# include # define PI int main(void) double r, s, v; scanf(%lf, &r); *PI*r*r ; v = 4.0/3.0*PI*r*r*r ; . return 0;19整型常量(整数)整型常量(整数)n整数的表示整数的表示三种表现形式:三种表现形式:十进制整数:正、负号,十进制

13、整数:正、负号,09,首位不是,首位不是0例:例: 10,123八进制整数:正、负号,八进制整数:正、负号,07,首位是,首位是0例:例: 010,012316进制整数:正、负号,进制整数:正、负号,09,a-f,A-F,前,前缀是缀是0 x,0X例:例:0 x10,0 x12320整数的表示整数的表示123 = 01111011 (B) 二进制二进制 =173 (O) 八进制八进制 =7B (X) 十六进制十六进制123 0173 0 x7b16 020 0 x1010 012 0XA10 010 0 x10n不能超出整型数据的取值范围不能超出整型数据的取值范围n比长整型数还要大的数只能用实

14、数来表示比长整型数还要大的数只能用实数来表示21整数的类型整数的类型判断整数的类型判断整数的类型n整数后的字母后缀整数后的字母后缀123L long123U unsigned123LU unsigned longn整数的值整数的值22实型常量(实数、浮点数)实型常量(实数、浮点数)n实数的表示实数的表示浮点表示法浮点表示法0.123 123.4 12. .12科学计数法科学计数法6.026E-27 1.2e+30 1E-5n实数的类型实数的类型double23字符型常量字符型常量n字符常量字符常量a A 9 + $ nASCII字符集字符集列出所有可用的字符(列出所有可用的字符(256个)个)

15、每个字符:惟一的次序值(每个字符:惟一的次序值( ASCII 码)码)0-9 升序排列升序排列A-Za-z24字符的数值特征字符的数值特征字符字符ASCII 码码对字符进行运算对字符进行运算 对字符的对字符的ASCII 码进行运算码进行运算例如:例如:A 的的 ASCII 码码 65则:则:A+1=66,对应字符对应字符 B区分数字字符和数字区分数字字符和数字 1 125转转义义字字符符n反斜杠后跟一个字符或数字反斜杠后跟一个字符或数字n字符常量,代表字符常量,代表一个一个字符字符 n 101 x41 An所有字符都可以用转义字符表示所有字符都可以用转义字符表示266.2.2 变量变量在程序运

16、行过程中,其值可以被改变的量。在程序运行过程中,其值可以被改变的量。n变量必须先定义,后使用变量必须先定义,后使用n定义变量时要指定变量名和数据类型定义变量时要指定变量名和数据类型n变量应该先赋值,后引用变量应该先赋值,后引用27变量的定义变量的定义n变量名:合法的标识符变量名:合法的标识符小写字母;见名知义小写字母;见名知义n变量的类型:在定义时指定变量的类型:在定义时指定n变量定义的一般形式变量定义的一般形式类型名类型名 变量名表;变量名表;int celsius, fahr; float x;double area, length;变量名变量名代表内存中的一个存储单元,存放该变量的值代表

17、内存中的一个存储单元,存放该变量的值该存储单元的大小由变量的该存储单元的大小由变量的数据类型数据类型决定决定28变量的使用变量的使用n必须先必须先定义定义,后,后使用使用n应该先赋值,后引用应该先赋值,后引用n变量的赋值方法变量的赋值方法变量赋初值:在定义变量时对它赋值变量赋初值:在定义变量时对它赋值int a = 5, b = 3;赋值表达式赋值表达式int a, b;a = 5;b = 3;输入输入int a, b;scanf(%d%d, &a, &b);296.3.1 整型数据的输入和输出整型数据的输入和输出6.3.2 实型实型数据的输入和输出数据的输入和输出6.3.3 字符型字符型数据

18、的输入和输出数据的输入和输出 6.3 数数据的输入和输出据的输入和输出 30 整型数据的输入输出整型数据的输入输出printf (格式控制格式控制, 输出参数输出参数1, . , 输出参数输出参数n);scanf (格式控制格式控制, 输入参数输入参数1, . , 输入参数输入参数n);格式控制说明格式控制说明 % 十进制十进制 八进制八进制 十六进制十六进制int %d %o %xlong %ld %lo %lxunsigned %u %o %xunsigned long %lu %lo %lx31例例6-2(1) 输出整型数据输出整型数据 # include int main(void)

19、printf(%d, %o, %xn, 10, 10, 10); printf(%d, %d, %dn, 10, 010, 0 x10); printf(%d, %xn, 012, 012); return 0; 00101010, 12, a10, 8, 1610, a32例例6-2(2) 输入整型数据输入整型数据# include int main(void) int a, b; printf(input a, b:); scanf(%o%d, &a, &b); printf(%d%5dn, a, b); printf(%x, %dn, a, b); return 0; input a,

20、b: 17 1715 17f, 17%x%d336.3.2 实型数据的输入和输出实型数据的输入和输出n输入输入 scanf()float:%f 或或%e 以小数或指数形式输入一个单精度浮点数以小数或指数形式输入一个单精度浮点数double: %lf或或%le 以小数或指数形式输入一个以小数或指数形式输入一个双精度双精度浮点数浮点数n输出输出 printf()float 和和double使用相同的格式控制说明使用相同的格式控制说明%f以小数形式输出浮点数,保留以小数形式输出浮点数,保留6位小数位小数%e以指数形式输出以指数形式输出34实型数据输出示例实型数据输出示例# include int m

21、ain(void) double d = 3.1415926; printf(%f, %en, d, d); printf(%5.3f, %5.2f, %.2fn, d, d, d); return 0; 3.141593, 3.14159e+00一共一共5位,小数位,小数3位,小数点一位位,小数点一位35实型数据输入输出示例实型数据输入输出示例假定假定float的精度为的精度为7位,位,double的精度为的精度为16位位 # include int main(void) float f; double d; printf(input f, d:); scanf(%f%lf, &f, &d)

22、; printf(f = %fn d = %f n, f, d); printf(d = %f n, d); return 0;input f, d: 366.3.3 字符型数据输入输出字符型数据输入输出nscanf() 和和 printf() %cchar ch;scanf(%c, &ch);printf(%c, ch);ngetchar() 和和 putchar()char ch;ch = getchar( );putchar(ch);输入输出一个字符输入输出一个字符37例6-3(1) 输入输出字符示例# include int main(void) char ch1, ch2; ch1=

23、getchar(); ch2=getchar(); putchar(ch1); putchar(#); putchar(ch2); return 0;AbA#b38例6-3(2) 输入输出字符示例# include int main(void) char ch1, ch2, ch3; scanf(%c%c%c, &ch1, &ch2, &ch3); printf(%c%c%c%c%c, ch1, #, ch2, #, ch3); return 0;AbCA#b#CA bCA# #b39例6-4 输出字符型数据b的的ASCII码码98# include int main(void) char c

24、h = b; printf(%c, %dn, b, b); printf(%c, %dn, 98, 98); printf(%c, %dn, 97, b-1); printf(%c, %dn, ch - a + A, ch - a + A); return 0;0110 0010b98b98b, 98b, 98a, 97B, 6640# include int main( ) char ch; ch = b; printf(%c, %dn, ch, ch); return 0;0110 0010b9814262b9801420 x62 printfb %c putchar98 %d142 %o

25、62 %x scanfb %c getchar98 %d142 %o62 %xscanf(%c, &ch);41字符运算字符运算n大小写英文字母转换大小写英文字母转换 b - a = B - A z - a = Z - A m M a-AA-a0lm - a + A = MlM - A + a = ml8 - 0 = 8l8 + 0 = 8n数字字符和数字数字字符和数字转换转换 9 - 0 = 9 - 0 9 = 9 + 08 842不同类型数据的混合运算,先转换为同一不同类型数据的混合运算,先转换为同一类型,再运算。类型,再运算。6.4.1 自动类型转换自动类型转换非赋值运算的类型转换非赋值

26、运算的类型转换赋值运算的类型转换赋值运算的类型转换6.4.2 强制类型转换强制类型转换6.4 类型转换类型转换436.4.1 自动类型转换(非赋值运算)自动类型转换(非赋值运算)n水平方向:自动水平方向:自动n垂直方向:低垂直方向:低 高高 高高 double float unsigned long long unsigned unsigned short 低低 int char, short44自动类型转换(非赋值运算)自动类型转换(非赋值运算)A + 12 10.05 65 77高高 double float unsigned long long unsigned unsigned sho

27、rt 低低 int char, short45自动类型转换(赋值运算)自动类型转换(赋值运算)变量变量 = 表达式表达式n计算赋值运算符右侧计算赋值运算符右侧表达式表达式的值的值n将赋值运算符右侧将赋值运算符右侧表达式表达式的值赋给左侧的的值赋给左侧的变量变量将赋值运算符右侧表达式的类型将赋值运算符右侧表达式的类型自动转换成自动转换成赋值号左侧变量的类型赋值号左侧变量的类型46自动类型转换(赋值运算)自动类型转换(赋值运算)double x;x = 1;x = ?short a = 1000;char b = A;long c;c = a + b;c = ?int ai;ai = 2.56;a

28、i = ?short bi;bi = 0 x12345678Lbi = ?475.4.2 强制类型转换强制类型转换强制类型转换运算符强制类型转换运算符(类型名类型名) 表达式表达式(double)3(double)(5/2)(double)5/2348强制类型转换示例强制类型转换示例# include int main(void) int i; double x; x = 3.8; i = (int) x; printf(x = %f, i = %d n, x, i); printf(double)(int)x = %fn, (double)(int)x); printf( x mod 3 =

29、 %dn, (int)x % 3); return 0;x = 3.800000, i = 3x mod 3 = 049表达式:由运算符和运算对象(操作数)组表达式:由运算符和运算对象(操作数)组成的有意义的运算式子,它的值和类型由成的有意义的运算式子,它的值和类型由参加运算的运算符和运算对象决定。参加运算的运算符和运算对象决定。运算符:具有运算功能的符号运算符:具有运算功能的符号运算对象:常量、变量和函数等表达式运算对象:常量、变量和函数等表达式算术表达式、赋值表达式、关系表达式、逻算术表达式、赋值表达式、关系表达式、逻辑表达式、条件表达式和逗号表达式等辑表达式、条件表达式和逗号表达式等 6

30、.5 表达式表达式 506.5.1 算术表达式算术运算符算术表达式算术运算符n单目单目 + - + -n双目双目 + - * / %注意注意/ 整数除整数,得整数整数除整数,得整数1/4 = 0,10/3 = 3% 模模(求余求余): 针对整型数据针对整型数据5%6 = 5,9%4 = 1,100%4 = 0+ 和和 n单目运算符,单目运算符, +10 和和 10n双目运算符,双目运算符, x+10 和和 y 10 双目运算符两侧操作数的类型要相同,否则,自动双目运算符两侧操作数的类型要相同,否则,自动类型转换后,再运算。类型转换后,再运算。51自增运算符自增运算符+和自减运算符和自减运算符-

31、int n;n+ +n n- -n (只适合变量运算)(只适合变量运算)使变量的值增使变量的值增1或减或减1+n n+ n = n + 1-n n- n = n - 1取变量的值作为表达式的值取变量的值作为表达式的值+n:n = n + 1;取取n值作为表达式值作为表达式 +n 的值的值n+:取取n值作为表达式值作为表达式 n+ 的值;的值;n = n + 152自增运算和自减运算自增运算和自减运算int n, m;n=2;m=+n;n=2;m=n+;n=3n=3m=3m=2m=nm=n+1n=n+1m=n53算术运算符的优先级和结合性算术运算符的优先级和结合性单目单目 + - + -双目双目

32、 * / %双目双目 + -高高低低从右向左从右向左-5 + 3%2 = (-5) + (3%2) = -43 * 5 % 3 = (3*5) % 3 = 0-i+ -(i+)54写出写出C表达式表达式数学式数学式 C算术表达式算术表达式s(s-a)(s-b)(s-c)(x+2)e2xaacbb242556.5.2 赋值赋值表达式表达式n赋值运算符赋值运算符 =x = 3*4优先级较低,结合性从右向左优先级较低,结合性从右向左x = y = 3 x = (y = 3)56赋值赋值表达式表达式变量变量 = 表达式表达式计算赋值运算符右侧计算赋值运算符右侧表达式表达式的值的值将赋值运算符右侧将赋值

33、运算符右侧表达式表达式的值赋给左侧的的值赋给左侧的变量变量将赋值运算符左侧的将赋值运算符左侧的变量变量的值作为表达式的值的值作为表达式的值右侧表达式的类型自动转换成左侧变量的类型右侧表达式的类型自动转换成左侧变量的类型int n; double x, y;n = 3.14 * 2;x = 10 / 4;x = (y = 3);57复合赋值运算符复合赋值运算符n赋值运算符赋值运算符简单赋值运算符简单赋值运算符 =复合赋值运算符复合赋值运算符n复合算术赋值运算符复合算术赋值运算符 += -= *= /= %=n复合位赋值运算符复合位赋值运算符n赋值表达式赋值表达式 变量变量 赋值运算符赋值运算符

34、表达式表达式x += exp 等价于等价于 x = x + expx *= y - 3x = x * (y-3) 586.5.3 关系表达式关系运算符关系表达式关系运算符n比较两个操作数,比较的结果:比较两个操作数,比较的结果:真真 假假x y x y x = y x != yn优先级优先级 算术运算符算术运算符 = = != 赋值运算符赋值运算符n左结合左结合a b = cd = a bch a + 1 d = a + b c3 = x b)= cd = (a b)ch (a + 1)d = (a + b) c)(3 = x) b = cd = a bch a + 1d = a + b cb - 1 = a != c3 = x = 3 & x = a & ch = A & ch = 3 & x =

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论