第三讲基本数据类型.ppt
第三讲 基本数据类型,2,第三讲 基本数据类型,引例变量与常量预备知识内储存器的组织数据类型基本数据类型整数类型字符浮点类型,C语言程序设计,3,引例,引例问题计算任意一个圆的面积。源程序(cw02-01.c),基本数据类型,#include void main()float r,area;/定义变量 scanf(“%f”,/输出,1area=3.140000,area,r,area=r2,4,变量与常量,数据(Data)程序需要使用数据。数据是信息的载体。数据有多种形式:数、字符、图片等。常量(Constants)在程序运行之前可以预先设定,并在整个运行过程中没有变化的数据。例如引例中的圆周率3.14。变量(Variables)在程序运行过程中可能变化或被赋值的数据。例如引例中的半径和面积。,基本数据类型,5,数据类型,数据类型的作用决定数据的存储方式和占用的存储空间的大小。决定可以进行的操作。C语言的数据类型基本类型整型(integer),字符型(character),浮点型(floating-point),枚举类型(enumeration)构造类型结构体(structure),共用体(union),数组(array)指针类型(pointer)空类型(void),基本数据类型,6,位、字节和字,内存储器的组织,基本数据类型,位(bit):最小的存储单位,可以容纳两个值之一,即0或1。,2000,2001,2002,字节(Byte):基本的存储单位,8位。,字(word):自然的存储单位,包含若干个字节。例如32位机的一个字就是32位。,地址:以字节为单位从0开始编号。,7,整数的存储方式,有符号的正整数在内存中以二进制补码形式存放。正整数的补码与原码相同。例如:10,基本数据类型,符号位,数轴,0,215-1=32767,可表示的数的范围,-215=-32768,8,整数的存储方式,有符号的负整数在内存中以二进制补码的形式存放。例如:-10,基本数据类型,符号位,9,整数的存储方式,无符号整数所有二进制位都存放数值。例如:65535,基本数据类型,0,216-1=65535,可表示的数的范围,10,整数的类型,C语言提供多种整数类型为程序员提供了针对不同用途的多种选择。,基本数据类型,C标准只规定:short int long最大最小值参考,仅供参考,实际值与所使用的操作系统、编译系统、机器有关。,11,整型常量,整型常量有三种形式:十进制(decimal)整数12 65 65535八进制(octal)整数:带前缀 0(zero)014 0101 0177777十六进制(hexadecimal)整数:带前缀 0 x 或 0X0 xc 0 x41 0 xffff默认类型是int,即有符号的基本整型。可以加上后缀 u 或 U 表示无符号整数,或者 l 或 L 表示长整数。0 xb5Lu,基本数据类型,12,整型变量,声明变量(Declaration)变量在使用之前必须被声明。声明语句的格式:举例,基本数据类型,.;,int counter;int width,height;short x,y;long number;,变量声明创建了变量:为变量分配了存储空间。,height,13,整型变量,初始化(Initialize)变量为变量赋一个初始值。可以在声明语句中初始化变量。举例变量获得值的方法直接赋值输入初始化,基本数据类型,int counter=0;int width=352,height=288;,初始化式,288,height,14,整型变量,输出变量的值可以使用printf()函数。与int类型对应的格式说明符是%d。举例(cw02-02a.c),基本数据类型,#include void main()int a,b;a=32767;b=-32768;printf(a=%d,b=%dn,a,b);,a=32767,b=-32768,15,整数的溢出,溢出整数太大,超出了整数类型的数值范围。使用printf()时与unsigned int类型对应的格式说明符是%u。举例(cw02-02b.c),基本数据类型,#include void main()int a,b;unsigned c,d;a=2147483647;b=a+1;c=4294967295;d=c+1;printf(a=%d,b=%dn,a,b);printf(c=%u,d=%u,c,d);,a=2147483647,b=-2147483648c=4294967295,d=0,?,16,整数的溢出,溢出结果分析结论a+1 的结果(2147483648)超出了基本整型变量 b 所能容纳(表示)的数值范围(-21474836482147483647)。请分析d的结果。,基本数据类型,0 1 1 1 1 1 1 1.1 1 1 1 1 1 1,1 0 0 0 0 0 0 0.0 0 0 0 0 0 0,a(2147483647),1 0 0 0 0 0 0 0.0 0 0 0 0 0 0,a+1(2147483648),b(-2147483648),12,加正数,减正数,17,字符的存储方式,字符编码计算机使用一种数字编码(整数)来表示字符,每一个字符都对应一个特定的整数。常用的编码是ASCII(美国信息交换用标准码)。7位二进制数,十进制码值范围从0到127。一般用一个字节保存,最高位为0。字符的存储方式与整数相同举例字母A的ASCII码值为65,那么在内存中以65的二进制形式存储,且占一个字节。,基本数据类型,01000001,18,字符的类型和字符变量,C语言的字符类型:char占一个字节;可视为一个有符号的整数。举例(cw02-03.c),基本数据类型,#include void main()char c1,c2;/声明字符变量 c1=97;/把一个整数赋值给字符变量 c2=c1-32;/字符变量可以进行算术运算 printf(c1=%c,c2=%cn,c1,c2);printf(c1=%d,c2=%dn,c1,c2);,c1=a,c2=Ac1=97,c2=65,19,字符常量,字符常量用单引号括起来的一个字符。x 9+C语言将字符常量视为int类型。举例(cw02-04.c)如果int类型为16位,char类型为8位,那么对于bc,将把b和c的ASCII码值存储在两个字节中,并把c赋值给变量c2。注意:不同系统处理方式不同,结果不同。,基本数据类型,char c1,c2;c1=a;c2=bc;,0 1 1 0 0 0 0 1,c1,0 1 1 0 0 0 1 1,c2,0 1 1 0 0 0 1 1,0 1 1 0 0 0 1 0,bc,L,H,97,99,99,98,20,字符常量,转义字符(escape character)指代一些特殊的字符。(打印不出来的字符)举例(cw02-05.c),基本数据类型,a 警报 反斜杠()b 退格?问号(?)f 走纸 单引号()n 换行“双引号(”)r 回车ooo 八进制值(o表示一个八进制数字)t 水平制表符xhh 十六进制值(h表示一个十六进制数字)v 垂直制表符,#include void main()printf(atbncbd100 x40n);,abd,21,浮点数的存储方式,浮点数浮点型数据在内存中按指数形式存放。例如:314.15=3.1415102,基本数据类型,由此可见,尾数部分的宽度决定了有效数字的个数(即精度),阶码部分的宽度决定了数值范围。,科学计数法允许使用少量的数字表示很大范围的数和很小的数。,22,浮点数的类型,浮点数也有多种类型类型名称及典型大小,基本数据类型,S=1参考,仅供参考,实际值与所使用的操作系统、编译系统、机器有关。,数轴,0,可表示的正数,可表示的负数,23,浮点型常量,浮点型常量有两种形式:十进制形式12.3.65 0.指数形式:1.2e-2.1E5 7E01.210-20.11057.0100默认类型是double。可以加上后缀 f 或 F 表示float类型,或者 l 或 L 表示long double类型,否则该常量是double类型。2.3f 1.2L.1E5f,基本数据类型,24,浮点型变量,浮点型变量的声明和初始化举例,基本数据类型,float radius;double x=0.0,y=0.0;,不能写成:double x=y=0.0;,25,浮点型变量,浮点数的输出使用printf()函数float和double对应的格式说明符为%f、%e。举例(cw02-06.c),基本数据类型,#include void main()float f;double d;f=33333.33333f;d=33333.3333333333;printf(f=%fnd=%f,f,d);,f=33333.332031d=33333.333333,有效数字位数是有限的,在可表示的有效位之外的数字被舍去。因此可能会产生误差。,26,浮点数的舍入误差,浮点数的舍入误差举例(cw02-07.c),基本数据类型,#include void main()float a,b;a=123456.789e5;b=a+20;printf(a=%fnb=%f,a,b);,a=12345678848.000000b=12345678848.000000,?,27,浮点数的舍入误差,浮点数的舍入误差结果分析,基本数据类型,a=123456.789e5;b=a+20;,a+20的理论值应该是:12345678920但是,一个实型变量能够保证的有效数字是7位,后面的数字将被舍去,是没有意义的。因此,最后得到b=12345678848.000000,应当避免一个很大的数和一个很小的数直接相加或相减,否则就会“丢失”较小的数。,28,浮点数的溢出,上溢举例(cw02-08.c)若某系统中的最大float值为3.4e38,进行如下操作得到结果下溢举例:假设-10是最小的指数,能够保留四位有效数字如果把数0.1234e-10除以10,将得到结果0.0123e-10,但损失了一位有效数字。,基本数据类型,float toobig=3.4e38*100.0f;printf(“toobig=%f,toobig);,inf,无穷大(infinity),29,小结,C语言有多种数据类型。基本的数据类型包括两大类:整数类型浮点类型开发程序时,应当注意所需变量及其类型的选择。一般使用int和float表示数,用char表示字符。在使用变量的函数的可执行语句之前声明该变量,并为它选择有意义的名字。初始化变量使用的常量应当与变量的类型相匹配。,基本数据类型,