03 第三章 C 数据类型2.pptVIP

  • 1
  • 0
  • 约2.86千字
  • 约 25页
  • 2015-09-15 发布于山西
  • 举报
03 第三章 C 数据类型2

第二章: C 数据类型 数据的表示 数值怎样以二进制数的形式存储在计算机内? ------编码 计算机内的二进制代码怎样表示不同的意义? ------数制转换 提示: 计算机只能识别二进制机器码,那么计算机怎样处理人们日常的事物呢? ------编码 数学运算很复杂,有整数运算、小数运算、正负数运算、位运算,运算过程各不相同,计算机怎样用二进制分别表示呢? ------数制转换、符号位/定/浮点表示及相关运算 总之:计算机用特定类型的数据表示特定信息 C 数据类型 数据类型转换 (1) 在C语言中,整型、实型和字符型数据间可以混合运算(因为字符数据与整型数据可以通用)。 如果一个运算符两侧的操作数的数据类型不同,则系统按“先转换、后运算”的原则,转换的方法有两种:自动转换(隐式转换);强制转换。 1、自动动转换(隐式转换) 自动转换发生在不同类型数据进行混合运算时,由编译系统自动完成。转换规则:(参看下页图示) (1) 类型不同,先转换为同一类型,然后进行运算。 数据类型转换 (2)图中纵向的箭头表示当运算对象为不同类型时转换的方向。可以看到箭头由低级别数据类型指向高级别数据类型,即数据总是由低级别向高级别转换。即按数据长度增加的方向进行,保证精度不降低。 (3)图中横向向左的箭头表示必定的转换(不必考虑其它运算对象)。如字符数据参与运算必定转化为整数,float型数据在运算时一律先转换为双精度型,以提高运算精度(即使是两个float型数据相加,也先都转换为double型,然后再相加)。 (4)赋值运算,如果赋值号“=”两边的数据类型不同,赋值号右边的类型转换为左边的类型。这种转换是截断型的转换,不会四舍五入。 强制转换 强制转换是通过类型转换运算来实现。 一般形式:(类型说明符)表达式 功能:把表达式的结果强制转换为类型说明符所表示的类型。 例如: (int)a 将a的结果强制转换为整型量。 (int)(x+y) 将x+y的结果强制转换为整型量。 (float)a+b 将a的内容强制转换为浮点数,再与b相加 说明:(1)类型说明和表达式都需要加括号(单个变量可以不加括号) (2)无论隐式转换,强制转换都是临时转换,不改变数据本身的类型和值。 例 main() { float f=5.75; printf((int)f=%d\n,(int)f); /* 将f的结果强制转换为整型,输出 */ printf(f=%f\n,f); /* 输出f的值 */ } 结果: (int)f=5 f=5.750000 * * 数据类型掌握要点: 1.不同类型的数据在内存中占据不同长度的存储区。 2.不同类型的数据取值范围不同。 3.不同类型的数据有不同的操作。 1.基本类型 2.构造类型 3.指针类型 整型 字符型 浮点型 单精度 双精度 数组 结构体 共用体 枚举 短整型 长整型 C语言中的数据,有常量和变量之分,它们分别属于上述这些类型。 一个字符存入一个字符变量。其对应单元存放的是其ASCII码的值,即ASCII码的二进制形式。 因此: 字符变量中的数据是一整型数据。输出时既可输出字符,亦可输出整数,且字符变量可作整数运算。 ? 字符数据的实际存放形式 例1: #include stdio.h main ( ) { char c1, c2; c1=97; /*ASCII码表中的序号值*/ c2=98; printf (”c1=%c ,c2= %c, c1, c2); } 运行结果: c1=a , c2= b 例 #include stdio.h main ( ) { char c1, c2; c1= a ; c2= b ; c1=c1– 32; c2=c2– 32; printf (”c1=%c, c2=%c, c1, c2); } 运行结果 c1=A , c2= B Char 型可以参与运算 算术运算符和算术表达式 一、算术运算符(表2-3) + 加法,正值。 如: 3+6, +3 – 减法,负值。 如: 6– 4, –5 ? 乘法。 如: 3?8 / 除法。 如: 8

文档评论(0)

1亿VIP精品文档

相关文档