第二章数据类型运算符与表达式Word下载.docx
《第二章数据类型运算符与表达式Word下载.docx》由会员分享,可在线阅读,更多相关《第二章数据类型运算符与表达式Word下载.docx(23页珍藏版)》请在冰豆网上搜索。
2、2常量与变量
2、2、1常量:
在程序的运行过程中,其值不能改变的量称为常量。
1、常量有不同的类型,如12、0、-3为整型常量,4.6、-1.23为实型常量,’a’、’d’字符常量。
常量可以从字面形式即可判断-字面常量或直接常量。
2、符号常量
#definePI3.1416
使用符号常量的好处:
(1)含义清楚、见名知意。
(2)修改方便、一改全改。
例2-1:
符号常量应用
#definePI3.14
main()
{
floatarea;
area=10*10*PI;
printf("
area=%f\n"
area);
}_
结果:
area=314.000000
2、2、2变量:
在程序的运行过程中,其值可以改变的量称为变量。
1、变量名(用标识符表示)、变量在内存中占据的存储单元、变量值三者关系。
变量名在程序运行过程中不会改变,变量的值可以改变。
变量名遵守标识符准则。
2、C语言中变量:
“先定义,后使用”。
即就是说,C要求对所有用到的变量做强制定义。
1)只有申明过的变量才可以在程序中使用,这使得变量名的拼写错误容易发现。
BASIC却不是这样。
有时你会用了两个相近似变量而你根本没有发现,却当作同一个变量在使用。
2)申明的变量属于确定的类型,编译系统可方便地检查变量所进行运算的合法性。
3)在编译时根据变量类型可以为变量确定存储空间,“先定义后使用”使程序效率高。
2、3整型数据
2、3、1整型常数的表示方法
三种形式:
(+/-)
1)十进制。
例如123,-456,0。
2)八进制。
以0开头,后面跟几位的数字(0-7)。
例如:
0123=(123)8=(83)10;
-011=(-11)8=(-9)10。
3)十六进制。
以0x开头,后面跟几位的数字(0-9,A-F)。
0x123=291,-0x12=-18。
4)整型常量的类型(整型常数的后缀)-在整型变量部分介绍,这里只要知道怎么表示。
整型常量后可以用:
u或U明确说明为无符号整型数
l或L明确说明为长整型数.
2、3、2整型变量
1、整型数据在内存中的存放形式
数据在内存中以二进制形式存放,事实上以补码形式存放。
定义一个整型变量i=10,
补充知识(参考《微机原理》等课程):
1)带符号数的表示,原码、反码、补码。
2)原码-补码相互转化。
正数的补码与其原码相同,负数的补码是其对应的原码数值位按位取反+1。
例题:
10,-10的计算机机内表示。
思路:
先将数值表示为二进制形式(十进制=>
二进制,除2取余),即获得数值的原码。
将原码转化为补码,就是机内表示。
10=(1010)2=(0000,0000,0000,1010)原=(0000,0000,0000,1010)补。
-10=(-1010)2=(1000,0000,0000,1010)原=(1111,1111,1111,0110)补。
从10,-10的计算机机内表示可以看出正数、负数机内表示(补码表示)看上去明显不同。
2、整型变量的分类
整型变量的基本类型为int。
通过加上修饰符,可定义更多的整数数据类型。
1)根据表达范围可以分为:
基本整型(int)、短整型(shortint)、长整型(longint)。
用long型可以获得大范围的整数,但同时会降低运算速度。
2)根据是否有符号可以分为:
有符号(signed,默认),无符号(unsigned)-目的:
扩大表示范围,有些情况只需要用正整数。
有符号整型数的存储单元的最高位是符号位(0:
正、1:
负),其余为数值位。
无符号整型数的存储单元的全部二进制位用于存放数值本身而不包含符号。
归纳起来可以用6种整型变量:
●有符号基本整型:
[signed]int
●有符号短整型:
[signed]short[int]
●有符号长整型:
[signed]long[int]
●无符号基本整型:
unsigned[int]
●无符号短整型:
unsignedshort[int]
●无符号长整型:
unsignedlong[int]
例子:
保存整数13的各种整型数据类型。
C标准没有具体规定上面数据类型所占用的字节数,只要求long型数据长度不短于int型,short型不长于int型。
具体如何实现,由各计算机系统自行决定。
如微机上short,int都是16位,而long是32位;
VAX750机,int,long都是32位,而short是16位。
3、整型变量的定义
格式:
数据类型名变量名表;
inta,b,c,d;
unsignedu;
a=12;
b=-24;
u=10;
c=a+u;
d=b+u;
printf(“%d,%d\n”,c,d);
}
说明:
(1)变量定义时,可以说明多个相同类型的变量。
各个变量用“,”分隔。
类型说明与变量名之间至少有一个空格间隔。
(2)最后一个变量名之后必须用“;
”结尾。
(3)变量说明必须在变量使用之前。
(4)可以在定义变量的同时,对变量进行初始化。
例2-2:
变量初始化
inta=3,b=5;
a+b=%d\n"
a+b);
4、整型数据的溢出
整型数最大允许值+1,最小允许值-1,会出现什么情况?
32767+1=-32768;
-32768-1=32767。
例2-2a:
整型数据的溢出
inta,b;
a=32767;
b=a+1;
\na=%d,a+1=%d\n"
a,b);
a=-32768;
b=a-1;
\na=%d,a-1=%d\n"
getch();
a=32767,a+1=-32768
a=-32768,a-1=32767
超出范围就发生“溢出”,运行时不报错。
2、4实型数据
2、4、1实型常量的表示方法
实数(浮点数)有两种表示形式:
1、十进制小数形式。
由数字,小数点组成(必须有小数点)。
.123、123.、123.0、0.0
2、指数形式。
aEn。
123e3、123E3都是实数的合法表示。
1)字母e或E之前必须有数字,e后面的指数必须为整数。
e3、2.1e3.5、.e3、e都不是合法的指数形式。
2)规范化的指数形式。
在字母e或E之前的小数部分,小数点左边应当有且只能有一位非0数字。
用指数形式输出时,是按规范化的指数形式输出的。
2.3478e2、3.0999E5、6.46832e12都属于规范化的指数形式。
3)实型常量都是双精度,如果要指定它为单精度,可以加后缀f(实型数据类型参看实型变量部分说明)。
2、4、2实型变量
1、实型数据在内存中的存放形式
一个实型数据一般在内存中占4个字节(32位)。
与整数存储方式不同,实型数据是按照指数形式存储的。
系统将实型数据分为小数部分和指数部分,分别存放。
实型数据存放的示意图。
标准C没有规定用多少位表示小数,多少位表示指数部分,由C编译系统自定。
例如,很多编译系统以24位表示小数部分,8位表示指数部分。
小数部分占的位数多,实型数据的有效数字多,精度高;
指数部分占的位数多,则表示的数值范围大。
2、实型变量的分类
实型变量分为:
单精度(float)、双精度(double)、长双精度(longdouble)。
ANSIC没有规定每种数据类型的长度、精度和数值范围。
表3.2列出微机上常用的C编译系统的情况,不同的系统会有差异。
表3.2
类型
比特数
有效数字
数值范围
float
32
6-7
-3.4x10+38~3.4x10+38
double
64
15-16
-1.7x10+308~1.7x10+308
longdouble
128
18-19
-1.2x10+4932~1.2x10+4932
对于每一个实型变量也都应该先定义后使用。
如:
floatx,y;
doublez;
longdoublet;
3、实型数据的舍入误差(对比:
整型数据的溢出)
实型变量是用有限的存储单元存储的,因此提供的有效数字是有限的,在有效位以外的数字将被舍去,由此可能会产生一些误差。
例2-3a:
实型数据的舍入误差(实型变量只能保证7位有效数字,后面的数字无意义)
floata,b;
a=123456.789e5;
b=a+20;
a=%f,b=%f\n"
a=%e,b=%e\n"
a=12345678848.000000,b=12345678848.000000
a=1.23457e+10,b=1.23457e+10
结论:
由于实数存在舍入误差,使用时要注意:
(a)不要试图用一个实数精确表示一个大整数,记住:
浮点数是不精确的。
(b)实数一般不判断“相等”,而是判断接近或近似。
(c)避免直接将一个很大的实数与一个很小的实数相加、相减,否则会“丢失”小的数。
(d)根据要求选择单精度、双精度。
例2-4:
根据精度要求,选择实数类型
floata;
doubleb;
a=33333.33333;
b=33333.3333333333;
2、4、3实型常量的类型
1、许多C编译系统将实型常量作为双精度实数来处理,这样可以保证较高的精度,缺点是运算速度降低。
在实数的后面加字符f或F,如1.65f、654.87F,使编译系统按单精度处理实数。
2、实型常量可以赋值给一个float、double、longdouble型变量。
根据变量的类型截取实型常量中相应的有效数字。
2、5字符型数据
2、5、