靳润昭C语言教程讲义 2001年2月17日 3数据类型、运算符与表达式 3.1 C语言的数据类型 常量与变量 3.2.1常量和符号常量 3.22变量 3.3 整型数据 3.3.1整型常量的表示方法 3.32整型变量 3.4 实型数据 341实型常量的表示方法 5889 342实型变量 343实型常数的类型 3.5字符型数据 3.51字符常量 3.52转义字符 0011 3.53字符变量 3.54字符数据在内存中的存储形式及使用方法 3.55字符串常量 3.56符号常量 错误!未定义书签 3.6变量赋初值 各类数值型数据之间的混合运算 3.8算术运算符和算术表达式 3.81C运算符简介 3.82算术运算符和算术表达式 3.9赋值运算符和赋值表达式 2B.34556800 3.10逗号运算符和逗号表达式… 3.1小结 3.1.1C的数据类型 3.12基本类型的分类及特点 3.1.3常量后缀 3.114常量类型 3..5数据类型转换 3.1.6运算符优先级和结合性 2222 3.11.7表达式 3数据类型、运算符与表达式 31c语言的数据类型 在第一章中,我们已经看到程序中使用的各种变量都应预先加以定义,即先定义,后 使用。对变量的定义可以包括三个方面: 第1页
靳润昭 C 语言教程讲义 2001 年 2 月 17 日 第1页 3 数据类型、运算符与表达式....................................................................................... 1 3.1 C语言的数据类型....................................................................................... 1 3.2 常量与变量................................................................................................. 3 3.2.1 常量和符号常量................................................................................... 3 3.2.2 变量..................................................................................................... 4 3.3 整型数据..................................................................................................... 4 3.3.1 整型常量的表示方法............................................................................ 4 3.3.2 整型变量.............................................................................................. 5 3.4 实型数据..................................................................................................... 8 3.4.1 实型常量的表示方法............................................................................ 8 3.4.2 实型变量.............................................................................................. 9 3.4.3 实型常数的类型................................................................................. 10 3.5 字符型数据............................................................................................... 10 3.5.1 字符常量............................................................................................ 10 3.5.2 转义字符.............................................................................................11 3.5.3 字符变量.............................................................................................11 3.5.4 字符数据在内存中的存储形式及使用方法........................................... 12 3.5.5 字符串常量........................................................................................ 13 3.5.6 符号常量..................................................................错误!未定义书签。 3.6 变量赋初值............................................................................................... 13 3.7 各类数值型数据之间的混合运算................................................................ 14 3.8 算术运算符和算术表达式.......................................................................... 15 3.8.1 C 运算符简介..................................................................................... 15 3.8.2 算术运算符和算术表达式................................................................... 16 3.9 赋值运算符和赋值表达式.......................................................................... 18 3.10 逗号运算符和逗号表达式.......................................................................... 20 3.11 小结.......................................................................................................... 20 3.11.1 C的数据类型..................................................................................... 20 3.11.2 基本类型的分类及特点....................................................................... 20 3.11.3 常量后缀............................................................................................ 21 3.11.4 常量类型............................................................................................ 21 3.11.5 数据类型转换..................................................................................... 21 3.11.6 运算符优先级和结合性....................................................................... 21 3.11.7 表达式............................................................................................... 21 3 数据类型、运算符与表达式 3.1 C语言的数据类型 在第一章中,我们已经看到程序中使用的各种变量都应预先加以定义,即先定义,后 使用。对变量的定义可以包括三个方面:
靳润昭C语言教程讲义 2001年2月17日 数据类型 ·存储类型 作用域 在本章中,我们只介绍数据类型的说明。其它说明在以后各章中陆续介绍。所谓数据类 型是按被定义变量的性质,表示形式,占据存储空间的多少,构造特点来划分的。在C语言 中,数据类型可分为:基本数据类型,构造数据类型,指针类型,空类型四大类。 数据类型 基本类型 整型 字符型 实型(浮点型) 单精度珏 奴精度型 枚举类型 构造类型 数组类型 结构体类型 共用体类型 指针类型 空类型 1.基本数据类型:基本数据类型最主要的特点是,其值不可以再分解为其它类型。也就是 说,基本数据类型是自我说明的。 构造数据类型:构造数据类型是根据已定义的一个或多个数据类型用构造的方法来定义 的。也就是说,一个构造类型的值可以分解成若干个“成员”或“元素”。每个“成员” 第2页
靳润昭 C 语言教程讲义 2001 年 2 月 17 日 第2页 ·数据类型 ·存储类型 ·作用域 在本章中,我们只介绍数据类型的说明。其它说明在以后各章中陆续介绍。所谓数据类 型是按被定义变量的性质,表示形式,占据存储空间的多少,构造特点来划分的。在C语言 中,数据类型可分为:基本数据类型,构造数据类型,指针类型,空类型四大类。 整型 字符型 单精度型 双精度型 实型(浮点型) 枚举类型 基本类型 数组类型 结构体类型 共用体类型 构造类型 指针类型 空类型 数据类型 1. 基本数据类型:基本数据类型最主要的特点是,其值不可以再分解为其它类型。也就是 说,基本数据类型是自我说明的。 2. 构造数据类型:构造数据类型是根据已定义的一个或多个数据类型用构造的方法来定义 的。也就是说,一个构造类型的值可以分解成若干个“成员”或“元素”。每个“成员
靳润昭C语言教程讲义 2001年2月17日 都是一个基本数据类型或又是一个构造类型。在C语言中,构造类型有以下几种 数组类型 结构体类型 共用体(联合)类型 3.指针类型:指针是一种特殊的,同时又是具有重要作用的数据类型。其值用来表示某个 变量在内存储器中的地址。虽然指针变量的取值类似于整型量,但这是两个类型完全不 同的量,因此不能混为一谈 4.空类型:在调用函数值时,通常应向调用者返回一个函数值。这个返回的函数值是具有 定的数据类型的,应在函数定义及函数说明中给以说明,例如在例题中给出的max 函数定义中,函数头为: int max(inta,intb,其中“int”类型说明符即表示该函数的返 回值为整型量。又如在例题中,使用了库函数sin,由于系统规定其函数返回值为双精 度浮点型,因此在赋值语句s=sin(x),中,s也必须是双精度浮点型,以便与sin函数的 返回值一致。所以在说明部分,把s说明为双精度浮点型。但是,也有一类函数,调用 后并不需要向调用者返回函数值,这种函数可以定义为“空类型”。其类型说明符为void 在后面函数中还要详细介绍 在本章中,我们先介绍基本数据类型中的整型、浮点型和字符型。其余类型在以后各章 中陆续介绍。 32常量与变量 对于基本数据类型量,按其取值是否可改变又分为常量和变量两种。在程序执行过程中 其值不发生改变的量称为常量,其值可变的量称为变量。它们可与数据类型结合起来分类 例如,可分为整型常量、整型变量、浮点常量、浮点变量、字符常量、字符变量、枚举常量、 枚举变量。在程序中,常量是可以不经说明而直接引用的,而变量则必须先定义后使用 整型量包括整型常量、整型变量 321常量和符号常量 在程序执行过程中,其值不发生改变的量称为常量。 直接常量(字面常量): 整型常量:12、0、-3 实型常量:46、-1.23 字符常量:‘a’、“b ●标识符:用来标识变量名、符号常量名、函数名、数组名、类型名、文件名的有效字符 序列。 符号常量:用标示符代表一个常量。在C语言中,可以用一个标识符来表示一个常量 称之为符号常量。 符号常量在使用之前必须先定义,其一般形式为: # define标识符常量 其中# define也是一条预处理命令(预处理命令都以"#"开头),称为宏定义命令(在 后面预处理程序中将进一步介绍),其功能是把该标识符定义为其后的常量值。一经定 义,以后在程序中所有出现该标识符的地方均代之以该常量值 习惯上符号常量的标识符用大写字母,变量标识符用小写字母,以示区别。 第3页
靳润昭 C 语言教程讲义 2001 年 2 月 17 日 第3页 都是一个基本数据类型或又是一个构造类型。在 C 语言中,构造类型有以下几种: ·数组类型 ·结构体类型 ·共用体(联合)类型 3. 指针类型:指针是一种特殊的,同时又是具有重要作用的数据类型。其值用来表示某个 变量在内存储器中的地址。虽然指针变量的取值类似于整型量,但这是两个类型完全不 同的量,因此不能混为一谈。 4. 空类型:在调用函数值时,通常应向调用者返回一个函数值。这个返回的函数值是具有 一定的数据类型的,应在函数定义及函数说明中给以说明,例如在例题中给出的 max 函数定义中,函数头为:int max(int a,int b);其中“int ”类型说明符即表示该函数的返 回值为整型量。又如在例题中,使用了库函数 sin,由于系统规定其函数返回值为双精 度浮点型,因此在赋值语句 s=sin (x);中,s 也必须是双精度浮点型,以便与 sin 函数的 返回值一致。所以在说明部分,把 s 说明为双精度浮点型。但是,也有一类函数,调用 后并不需要向调用者返回函数值,这种函数可以定义为“空类型”。其类型说明符为 void。 在后面函数中还要详细介绍。 在本章中,我们先介绍基本数据类型中的整型、浮点型和字符型。其余类型在以后各章 中陆续介绍。 3.2 常量与变量 对于基本数据类型量,按其取值是否可改变又分为常量和变量两种。在程序执行过程中, 其值不发生改变的量称为常量,其值可变的量称为变量。它们可与数据类型结合起来分类。 例如,可分为整型常量、整型变量、浮点常量、浮点变量、字符常量、字符变量、枚举常量、 枚举变量。在程序中,常量是可以不经说明而直接引用的,而变量则必须先定义后使用。 整型量包括整型常量、整型变量。 3.2.1 常量和符号常量 在程序执行过程中,其值不发生改变的量称为常量。 ⚫ 直接常量(字面常量): ◼ 整型常量:12、0、-3; ◼ 实型常量:4.6、-1.23; ◼ 字符常量:‘a’、‘b’。 ⚫ 标识符:用来标识变量名、符号常量名、函数名、数组名、类型名、文件名的有效字符 序列。 ⚫ 符号常量:用标示符代表一个常量。在C语言中,可以用一个标识符来表示一个常量, 称之为符号常量。 符号常量在使用之前必须先定义,其一般形式为: #define 标识符 常量 其中#define 也是一条预处理命令(预处理命令都以"#"开头),称为宏定义命令(在 后面预处理程序中将进一步介绍),其功能是把该标识符定义为其后的常量值。一经定 义,以后在程序中所有出现该标识符的地方均代之以该常量值。 ⚫ 习惯上符号常量的标识符用大写字母,变量标识符用小写字母,以示区别
靳润昭C语言教程讲义 2001年2月17日 【例3.1】符号常量的使用 #define Price 30 int num. total num=10 total=num* PRICE printf("total=%d, total) 用标识符代表一个常量,称为符号常量。 符号常量与变量不同,它的值在其作用域内不能改变,也不能再被赋值 ■使用符号常量的好处是: 含义清楚 能做到“一改全改”。 322变量 其值可以改变的量称为变量。一个变量应该有一个名字,在内存中占据一定的存储单元。 变量定义必须放在变量使用之前。一般放在函数体的开头部分。要区分变量名和变量值是两 个不同的概念 变量名 变量值 存储单元 33整型数据 331整型常量的表示方法 整型常量就是整常数。在C语言中,使用的整常数有八进制、十六进制和十进制三 种 1)十进制整常数:十进制整常数没有前缀。其数码为0~9 以下各数是合法的十进制整常数 237、-568、65535、1627 以下各数不是合法的十进制整常数: 023(不能有前导0)、23D(含有非十进制数码) 在程序中是根据前缀来区分各种进制数的。因此在书写常数时不要把前缀弄错造成 第4页
靳润昭 C 语言教程讲义 2001 年 2 月 17 日 第4页 【例 3.1】符号常量的使用。 #define PRICE 30 main() { int num,total; num=10; total=num* PRICE; printf(“total=%d”,total); } ◼ 用标识符代表一个常量,称为符号常量。 ◼ 符号常量与变量不同,它的值在其作用域内不能改变,也不能再被赋值。 ◼ 使用符号常量的好处是: ➢ 含义清楚; ➢ 能做到“一改全改”。 3.2.2 变量 其值可以改变的量称为变量。一个变量应该有一个名字,在内存中占据一定的存储单元。 变量定义必须放在变量使用之前。一般放在函数体的开头部分。要区分变量名和变量值是两 个不同的概念。 3.3 整型数据 3.3.1 整型常量的表示方法 整型常量就是整常数。在C语言中,使用的整常数有八进制、十六进制和十进制三 种。 1) 十进制整常数:十进制整常数没有前缀。其数码为 0~9。 以下各数是合法的十进制整常数: 237、-568、65535、1627; 以下各数不是合法的十进制整常数: 023 (不能有前导 0)、23D (含有非十进制数码)。 在程序中是根据前缀来区分各种进制数的。因此在书写常数时不要把前缀弄错造成 a 变量名 3 变量值 存储单元 变量名
靳润昭C语言教程讲义 2001年2月17日 结果不正确 2)八进制整常数:八进制整常数必须以0开头,即以0作为八进制数的前缀。数码取 值为0~7。八进制数通常是无符号数 以下各数是合法的八进制数: 015(十进制为13)、0101(十进制为65)、01777进制为65535) 以下各数不是合法的八进制数: 256(无前缀0)、03A2(包含了非八进制数码)、-0127(出现了负号) 3)十六进制整常数:十六进制整常数的前缀为0X或0x。其数码取值为09,AF或 以下各数是合法的十六进制整常数: 0X2A(十进制为42)、0XA0(十进制为160)、0 XFFFF(十进制为65535 以下各数不是合法的十六进制整常数 5A(无前缀0X)、0X3H(含有非十六进制数码)。 4)整型常数的后缀:在16位字长的机器上,基本整型的长度也为16位,因此表示的 数的范围也是有限定的。十进制无符号整常数的范围为0~65535,有符号数为 -32768~+32767。八进制无符号数的表示范围为0~017777六进制无符号数 的表示范围为0X0~0 XFFFF或0x0~0 XFFFF。如果使用的数超过了上述范围,就 必须用长整型数来表示。长整型数是用后缀“L”或“l”来表示的。 例如 十进制长整常数: 58L(十进制为158)、358000(十进制为358000) 八进制长整常数: 012L(十进制为10)、07(+进制为63)、020000进制为65536) 十六进制长整常数 0X5L(十进制为21)、0XA5L(十进制为165)、0X1000(进制为65536) 长整数158L和基本整常数158在数值上并无区别。但对158L,因为是长整型量 C编译系统将为它分配4个字节存储空间。而对158,因为是基本整型,只分配2个字 节的存储空间。因此在运算和输出格式上要予以注意,避免出错 无符号数也可用后缀表示,整型常数的无符号数的后缀为“U”或“u”。 例如 358u,0x38Au,235u均为无符号数。 前缀,后缀可同时使用以表示各种类型的数。如0XA5Lu表示十六进制无符号长 整数A5,其十进制为16 332整型变量 1.整型数据在内存中的存放形式 如果定义了一个整型变量i: ;10 第5页
靳润昭 C 语言教程讲义 2001 年 2 月 17 日 第5页 结果不正确。 2) 八进制整常数:八进制整常数必须以 0 开头,即以 0 作为八进制数的前缀。数码取 值为 0~7。八进制数通常是无符号数。 以下各数是合法的八进制数: 015(十进制为 13)、0101(十进制为 65)、0177777(十进制为 65535); 以下各数不是合法的八进制数: 256(无前缀 0)、03A2(包含了非八进制数码)、-0127(出现了负号)。 3) 十六进制整常数:十六进制整常数的前缀为 0X 或 0x。其数码取值为 0~9,A~F 或 a~f。 以下各数是合法的十六进制整常数: 0X2A(十进制为 42)、0XA0 (十进制为 160)、0XFFFF (十进制为 65535); 以下各数不是合法的十六进制整常数: 5A (无前缀 0X)、0X3H (含有非十六进制数码)。 4) 整型常数的后缀:在 16 位字长的机器上,基本整型的长度也为 16 位,因此表示的 数的范围也是有限定的。十进制无符号整常数的范围为 0~65535,有符号数为 -32768~+32767。八进制无符号数的表示范围为 0~0177777。十六进制无符号数 的表示范围为 0X0~0XFFFF 或 0x0~0xFFFF。如果使用的数超过了上述范围,就 必须用长整型数来表示。长整型数是用后缀“L”或“l”来表示的。 例如: 十进制长整常数: 158L (十进制为 158)、358000L (十进制为 358000); 八进制长整常数: 012L (十进制为 10)、077L (十进制为 63)、0200000L (十进制为 65536); 十六进制长整常数: 0X15L (十进制为 21)、0XA5L (十进制为 165)、0X10000L (十进制为 65536)。 长整数 158L 和基本整常数 158 在数值上并无区别。但对 158L,因为是长整型量, C编译系统将为它分配 4 个字节存储空间。而对 158,因为是基本整型,只分配 2 个字 节的存储空间。因此在运算和输出格式上要予以注意,避免出错。 无符号数也可用后缀表示,整型常数的无符号数的后缀为“U”或“u”。 例如: 358u,0x38Au,235Lu 均为无符号数。 前缀,后缀可同时使用以表示各种类型的数。如 0XA5Lu 表示十六进制无符号长 整数 A5,其十进制为 165。 3.3.2 整型变量 1. 整型数据在内存中的存放形式 如果定义了一个整型变量 i: int i; i=10; i 10
靳润昭C语言教程讲义 2001年2月17日 00oooooolololololiolio 数值是以补码表示的 ■正数的补码和原码相同 ■负数的补码:将该数的绝对值的二进制形式按位取反再加1。 例如 求-10的补码 10的原码 100oooolooloolool1olllol 取反: 山山山山山山山o山o 再加1,得-10的补码 山 1111111110110 由此可知,左面的第一位是表示符号的 2.整型变量的分类 1)基本型:类型说明符为int,在内存中占2个字节 2)短整量:类型说明符为 short int或 short。所占字节和取值范围均与基本型相同 3)长整型:类型说明符为 long int或long,在内存中占4个字节 4)无符号型:类型说明符为 unsigned 无符号型又可与上述三种类型匹配而构成 无符号短整型:类型说明符为 unsigned short, signed 无符号基本型:类型说明符为 unsigned int或 unsigned 无符号长整型:类型说明符为 unsigned long 各种无符号类型量所占的内存空间字节数与相应的有符号类型量相同。但由于省去了符 号位,故不能表示负数。 有符号整型变量:最大表示32767 o山山 无符号整型变量:最大表示65535 下表列出了 Turbo C中各类整型量所分配的内存字节数及数的表示范围 匚类型说明符 数的范围 字节数 -32768~32767 unsigned int 0~65535 即0~(216-1) 32768~32767 即-215~(215-1) unsigned short int 0-65535 即0~(216-1) 2 -2147483648-2147483647即-231~(231-1) 4 unsigned long 0~4294967295 即0~(232-1) 以13为例 0000000000001101 第6页
靳润昭 C 语言教程讲义 2001 年 2 月 17 日 第6页 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 0 数值是以补码表示的: ◼ 正数的补码和原码相同; ◼ 负数的补码:将该数的绝对值的二进制形式按位取反再加 1。 例如: 求-10 的补码: 10 的原码: 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 0 取反: 1 1 1 1 1 1 1 1 1 1 1 1 0 1 0 1 再加 1,得-10 的补码: 1 1 1 1 1 1 1 1 1 1 1 1 0 1 1 0 由此可知,左面的第一位是表示符号的。 2. 整型变量的分类 1) 基本型:类型说明符为 int,在内存中占 2 个字节。 2) 短整量:类型说明符为 short int 或 short。所占字节和取值范围均与基本型相同。 3) 长整型:类型说明符为 long int 或 long,在内存中占 4 个字节。 4) 无符号型:类型说明符为 unsigned。 无符号型又可与上述三种类型匹配而构成: ◼ 无符号基本型:类型说明符为 unsigned int 或 unsigned。 ◼ 无符号短整型:类型说明符为 unsigned short。 ◼ 无符号长整型:类型说明符为 unsigned long。 各种无符号类型量所占的内存空间字节数与相应的有符号类型量相同。但由于省去了符 号位,故不能表示负数。 有符号整型变量:最大表示 32767 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 无符号整型变量:最大表示 65535 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 下表列出了 Turbo C 中各类整型量所分配的内存字节数及数的表示范围。 类型说明符 数的范围 字节数 int -32768~32767 即-2 15~(2 15 -1) 2 unsigned int 0~65535 即 0~(2 16 -1) 2 short int -32768~32767 即-2 15~(2 15 -1) 2 unsigned short int 0~65535 即 0~(2 16 -1) 2 long int -2147483648~2147483647 即-2 31~(2 31 -1) 4 unsigned long 0~4294967295 即 0~(2 32 -1) 4 以 13 为例: int 型: 00 00 00 00 00 00 11 01
靳润昭C语言教程讲义 2001年2月17日 short int型: 0o 00000000 0011 o1 000000000000m unsigned short int型: 1101 0000000000 000000|000000000011101 3.整型变量的定义 变量定义的一般形式为 类型说明符变量名标识符,变量名标识符, 例如 a,b,c;(a,b,c为整型变量) long,y;(xy为长整型变量) unsigned p, q,(pq为无符号整型变量) 在书写变量定义时,应注意以下几点: 允许在一个类型说明符后,定义多个相同类型的变量。各变量名之间用逗号间隔。 类型说明符与变量名之间至少用一个空格间隔 最后一个变量名之后必须以“;”号结尾。 变量定义必须放在变量使用之前。一般放在函数体的开头部分。 【例3.2】整型变量的定义与使用。 maino int a b c d c=a+u d=b+u printf("atu%d, b+u%dn, c, d 4.整型数据的溢出 【例3.3】整型数据的溢出。 mal a=32767 b=a+1; printf("%d, %d\n", a, b); 第7页
靳润昭 C 语言教程讲义 2001 年 2 月 17 日 第7页 short int 型: 00 00 00 00 00 00 11 01 long int 型: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 11 01 unsigned int 型: 00 00 00 00 00 00 11 01 unsigned short int 型: 00 00 00 00 00 00 11 01 unsigned long int 型: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 11 01 3. 整型变量的定义 变量定义的一般形式为: 类型说明符 变量名标识符,变量名标识符,...; 例如: int a,b,c; (a,b,c 为整型变量) long x,y; (x,y 为长整型变量) unsigned p,q; (p,q 为无符号整型变量) 在书写变量定义时,应注意以下几点: ◼ 允许在一个类型说明符后,定义多个相同类型的变量。各变量名之间用逗号间隔。 类型说明符与变量名之间至少用一个空格间隔。 ◼ 最后一个变量名之后必须以“;”号结尾。 ◼ 变量定义必须放在变量使用之前。一般放在函数体的开头部分。 【例 3.2】整型变量的定义与使用。 main() { int a,b,c,d; unsigned u; a=12;b=-24;u=10; c=a+u;d=b+u; printf(“a+u=%d,b+u=%d\n”,c,d); } 4. 整型数据的溢出 【例 3.3】整型数据的溢出。 main() { int a,b; a=32767; b=a+1; printf("%d,%d\n",a,b); }
靳润昭C语言教程讲义 2001年2月17日 po山山山山山山山山山山山 32768 1000oooloolololololololo 【例3.4】 int a, b, c, d b=8; printf("c=x+a=%d, d=y+b=%d\n",c, d); 从程序中可以看到:xy是长整型变量,a,b是基本整型变量。它们之间允许进行运算, 运算结果为长整型。但c,d被定义为基本整型,因此最后结果为基本整型。本例说明,不 同类型的量可以参与运算并相互赋值。其中的类型转换是由编译系统自动完成的。有关类型 转换的规则将在以后介绍。 34实型数据 341实型常量的表示方法 实型也称为浮点型。实型常量也称为实数或者浮点数。在C语言中,实数只采用十进 制。它有二种形式:十进制小数形式,指数形式 1)十进制数形式:由数码0~9和小数点组成 例如: 0.0、25.0、5.789、0.13、5.0、300.、-2678230 等均为合法的实数。注意,必须有小数点 2)指数形式:由十进制数,加阶码标志“e”或“E”以及阶码(只能为整数,可以带符 号)组成 其一般形式为: aEn(a为十进制数,n为十进制整数) 其值为a*10 21E5(等于2.1*105) 37E-2(等于3.7*102) 第8页
靳润昭 C 语言教程讲义 2001 年 2 月 17 日 第8页 32767: 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 -32768 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 【例 3.4】 main(){ long x,y; int a,b,c,d; x=5; y=6; a=7; b=8; c=x+a; d=y+b; printf("c=x+a=%d,d=y+b=%d\n",c,d); } 从程序中可以看到:x, y 是长整型变量,a, b 是基本整型变量。它们之间允许进行运算, 运算结果为长整型。但 c,d 被定义为基本整型,因此最后结果为基本整型。本例说明,不 同类型的量可以参与运算并相互赋值。其中的类型转换是由编译系统自动完成的。有关类型 转换的规则将在以后介绍。 3.4 实型数据 3.4.1 实型常量的表示方法 实型也称为浮点型。实型常量也称为实数或者浮点数。在C语言中,实数只采用十进 制。它有二种形式:十进制小数形式,指数形式。 1) 十进制数形式:由数码 0~ 9 和小数点组成。 例如: 0.0、25.0、5.789、0.13、5.0、300.、-267.8230 等均为合法的实数。注意,必须有小数点。 2) 指数形式:由十进制数,加阶码标志“e”或“E”以及阶码(只能为整数,可以带符 号)组成。 其一般形式为: a E n(a 为十进制数,n 为十进制整数) 其值为 a*10n。 如: 2.1E5 (等于 2.1*105 ) 3.7E-2 (等于 3.7*10-2 )
靳润昭C语言教程讲义 2001年2月17日 0.5E7(等于0.5*107) 28E-2(等于-2.8*102) 以下不是合法的实数: 345(无小数点) E7(阶码标志E之前无数 -5(无阶码标志) 53.E3(负号位置不对) 27E(无阶码) 标准C允许浮点数使用后缀。后缀为“f”或“F”即表示该数为浮点数。如356f和356 是等价的。 【例3.5】说明了这种情况 main(i printf("%fn"356); printf("%fn" 356); print( 342实型变量 实型数据在内存中的存放形式 实型数据一般占4个字节(32位)内存空间。按指数形式存储。实数3.14159在内存中 的存放形式如下: 314159 数符 小数部分 指数 小数部分占的位(bt)数愈多,数的有效数字愈多,精度愈高。 指数部分占的位数愈多,则能表示的数值范围愈大 2.实型变量的分类 实型变量分为:单精度(ioat型)、双精度( double型)和长双精度( (long double型) 三类。 在 Turbo C中单精度型占4个字节(32位)内存空间,其数值范围为3.4E-38~34E+38 只能提供七位有效数字。双精度型占8个字节(64位)内存空间,其数值范围为17E-308 1.7E+308,可提供16位有效数字 类型说明符|比特数(字节数)有效数字 数的范围 float 32(4) double 64(8) 15~16 long double 128(16) 18~1 104931~104932 实型变量定义的格式和书写规则与整型相同。 例如: float,y;(xy为单精度实型量) double a, b,c;(ab,c为双精度实型量) 3.实型数据的舍入误差 第9页
靳润昭 C 语言教程讲义 2001 年 2 月 17 日 第9页 0.5E7 (等于 0.5*107 ) -2.8E-2 (等于-2.8*10-2 ) 以下不是合法的实数: 345 (无小数点) E7 (阶码标志 E 之前无数字) -5 (无阶码标志) 53.-E3 (负号位置不对) 2.7E (无阶码) 标准C允许浮点数使用后缀。后缀为“f”或“F”即表示该数为浮点数。如 356f 和 356. 是等价的。 【例 3.5】说明了这种情况。 main(){ printf("%f\n ",356.); printf("%f\n ",356); printf("%f\n ",356f); } 3.4.2 实型变量 1. 实型数据在内存中的存放形式 实型数据一般占 4 个字节(32 位)内存空间。按指数形式存储。实数 3.14159 在内存中 的存放形式如下: + .314159 1 数符 小数部分 指数 ⚫ 小数部分占的位(bit)数愈多,数的有效数字愈多,精度愈高。 ⚫ 指数部分占的位数愈多,则能表示的数值范围愈大。 2. 实型变量的分类 实型变量分为:单精度(float 型)、双精度(double 型)和长双精度(long double 型) 三类。 在 Turbo C 中单精度型占 4 个字节(32 位)内存空间,其数值范围为 3.4E-38~3.4E+38, 只能提供七位有效数字。双精度型占 8 个字节(64 位)内存空间,其数值范围为 1.7E-308~ 1.7E+308,可提供 16 位有效数字。 类型说明符 比特数(字节数) 有效数字 数的范围 float 32(4) 6~7 10-37~1038 double 64(8) 15~16 10-307~10308 long double 128(16) 18~19 10-4931~104932 实型变量定义的格式和书写规则与整型相同。 例如: float x,y; (x,y 为单精度实型量) double a,b,c; (a,b,c 为双精度实型量) 3. 实型数据的舍入误差
靳润昭C语言教程讲义 2001年2月17日 由于实型变量是由有限的存储单元组成的,因此能提供的有效数字总是有限的。如下例 【例36】实型数据的舍入误差 a=123456.7895 printf("%f\n", a printf("%f\n",b); 注意:1.0/3*3的结果并不等于1。 例 3.7】 maino float a double b. a=33333.33333 b=33333.33333333333 printf("%f\n%f\n",a, b) 从本例可以看出,由于a是单精度浮点型,有效位数只有七位。而整数已占五位, 故小数二位后之后均为无效数字 ●b是双精度型,有效位为十六位。但 Turbo C规定小数后最多保留六位,其余部 分四舍五入 343实型常数的类型 实型常数不分单、双精度,都按双精度 double型处理。 35字符型数据 字符型数据包括字符常量和字符变量 351字符常量 字符常量是用单引号括起来的一个字符。 例如: a'、b、曰、"'、"? 都是合法字符常量。 第10页
靳润昭 C 语言教程讲义 2001 年 2 月 17 日 第10页 由于实型变量是由有限的存储单元组成的,因此能提供的有效数字总是有限的。如下例。 【例 3.6】实型数据的舍入误差。 main() {float a,b; a=123456.789e5; b=a+20 printf("%f\n",a); printf("%f\n",b); } 注意:1.0/3*3 的结果并不等于 1。 【例 3.7】 main() { float a; double b; a=33333.33333; b=33333.33333333333333; printf("%f\n%f\n",a,b); } ⚫ 从本例可以看出,由于 a 是单精度浮点型,有效位数只有七位。而整数已占五位, 故小数二位后之后均为无效数字。 ⚫ b 是双精度型,有效位为十六位。但 Turbo C 规定小数后最多保留六位,其余部 分四舍五入。 3.4.3 实型常数的类型 实型常数不分单、双精度,都按双精度 double 型处理。 3.5 字符型数据 字符型数据包括字符常量和字符变量。 3.5.1 字符常量 字符常量是用单引号括起来的一个字符。 例如: 'a'、'b'、'='、'+'、'?' 都是合法字符常量