C语言入门之数据类型(2)

发表于:2007-07-14来源:作者:点击数: 标签:
C语言入门之数据类型(2): 整型变量 整型变量可分为以下几类: 1.基本型 类型说明符为int,在内存中占2个字节,其取值为基本整常数。 2.短整量 类型说明符为short int或short'C110F1。所占字节和取值范围均与基本型相同。 3.长整型 类型说明符为long int或lo
C语言入门之数据类型(2):

  整型变量

  整型变量可分为以下几类:

  1.基本型

  类型说明符为int,在内存中占2个字节,其取值为基本整常数。

  2.短整量

  类型说明符为short int或short'C110F1。所占字节和取值范围均与基本型相同。

  3.长整型

  类型说明符为long int或long ,在内存中占4个字节,其取值为长整常数。

  4.无符号型

  类型说明符为unsigned。

  无符号型又可与上述三种类型匹配而构成:

  (1)无符号基本型 类型说明符为unsigned int或unsigned。

  (2)无符号短整型 类型说明符为unsigned short

  (3)无符号长整型 类型说明符为unsigned long

  各种无符号类型量所占的内存空间字节数与相应的有符号类型量相同。但由于省去了符号位,故不能表示负数。 下表列出了Turbo C中各类整型量所分配的内存字节数及数的表示范围。

类型说明符    数的范围     分配字节数
int       -32768~32767     ■■
short int    -32768~32767     ■■
signed int    -32768~32767     ■■
unsigned int   0~65535        ■■
long int  -2147483648~2147483647  ■■■■
unsigned long  0~4294967295     ■■■■

  整型变量的说明

  变量说明的一般形式为: 类型说明符 变量名标识符,变量名标识符,...; 例如:

int a,b,c; (a,b,c为整型变量)
long x,y; (x,y为长整型变量)
unsigned p,q; (p,q为无符号整型变量)

  在书写变量说明时,应注意以下几点:

  1.允许在一个类型说明符后,说明多个相同类型的变量。各变量名之间用逗号间隔。类型说明符与变量名之间至少用一个空格间隔。

  2.最后一个变量名之后必须以“;”号结尾。

  3.变量说明必须放在变量使用之前。一般放在函数体的开头部分。

[Practice] //1int a,b;
short int c;
short d=100;
a=d-20;
b=a+d;
c=a+b+d;
d=d-a+c-b;'Vtable
a,2,0
b,2,0
c,2,0
d,2,100
of Vtable
'Vupdate
1,0;2,0
3,0
4,100
1,80
2,180
3,360
4,200
of Vupdate
of Practice
[Practice] //2int a=5;
int b=9;
long int c;
long d;
c=a+b-7;
d=a*b*c;
c=d*d*d;
a=c-d;'Vtable
a,2,5
b,2,9
c,4,0
d,4,0
of Vtable
'Vupdate
1,5
2,9
3,0
4,0
3,7
4,315
3,31255875
1,-5112
of Vupdate
of Practice
[Practice] //3int a=6,b=19;
unsigned int c;
int d;
c=a-b+7;
d=b*c;
a=b+c+d;
b=-a;'Vtable
a,2,6
b,2,19
c,2,0
d,2,0
of Vtable
'Vupdate
1,6;2,19
3,0
4,0
3,65530
4,-114
1,-101
2,101
of Vupdate
of Practice
void 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);
}

  将main说明为返回void,即不返回任何类型的值

  x,y被定义为long型

  a,b,c,d被定义为int型

5->x
6->y
7->a
8->b
x+a->c
y+b->d

  显示程序运行结果 of long x,y;

int a,b,c,d;
c=x+a;
d=y+b;

  从程序中可以看到:x, y是长整型变量,a, b是基本整型变量。它们之间允许进行运算,运算结果为长整型。但c,d被定义为基本整型,因此最后结果为基本整型。本例说明,不同类型的量可以参与运算并相互赋值。其中的类型转换是由编译系统自动完成的。有关类型转换的规则将在以后介绍。

  实型量

  实型常量

  实型也称为浮点型。实型常量也称为实数或者浮点数。在C语言中,实数只采用十进制。它有二种形式: 十进制数形式指数形式

  1.十进制数形式

  由数码0~ 9和小数点组成。例如:0.0,.25,5.789,0.13,5.0,300.,-267.8230等均为合法的实数 。

  2.指数形式

  由十进制数,加阶码标志“e”或“E”以及阶码(只能为整数,可以带符号)组成。其一般形式为a E n (a为十进制数,n为十进制整数)其值为 a*10,n 如: 2.1E5 (等于2.1*10,5), 3.7E-2 (等于3.7*10,)-2*) 0.5E7 (等于0.5*10,7), -2.8E-2 (等于-2.8*10,)-2*)以下不是合法的实数 345 (无小数点) E7 (阶码标志E之前无数字)  -5 (无阶码标志) 53.-E3 (负号位置不对) 2.7E (无阶码)
标准C允许浮点数使用后缀。后缀为“f”或“F”即表示该数为浮点数。如356f和356.是等价的。例2.2说明了这种情况:

void main()
{
printf("%f\n%f\n",356.,356f);
}


  void 指明main不返回任何值 利用printf显示结果 结束

  实型变量

  实型变量分为两类:单精度型和双精度型,其类型说明符为float 单精度说明符,double 双精度说明符。在Turbo C中单精度型占4个字节(32位)内存空间,其数值范围为3.4E-38~3.4E+38,只能提供七位有效数字。双精度型占8 个字节(64位)内存空间,其数值范围为1.7E-308~1.7E+308,可提供16位有效数字。

  实型变量说明的格式和书写规则与整型相同。

  例如: float x,y; (x,y为单精度实型量)

    double a,b,c; (a,b,c为双精度实型量)

  实型常数不分单、双精度,都按双精度double型处理。

void main(){
 float a;
 double b;
 a=33333.33333;
 b=33333.33333333333333;
 printf("%f\n%f\n",a,b);
}


  此程序说明float、double的不同

a ■■■■
b ■■■■■■■■
a<---33333.33333
b<---33333.33333333333;;

  显示程序结果

  此程序说明float、double的不同

float a;
double b;
a=33333.33333;
b=33333.33333333333333;

  从本例可以看出,由于a 是单精度浮点型,有效位数只有七位。而整数已占五位,故小数二位后之后均为无效数字。b 是双精度型,有效位为十六位。但Turbo C 规定小数后最多保留六位,其余部分四舍五入。

[Practice] //floatint a=32;
float b;
double d;
b=12345678;
d=b*100;
d=d+a;
d=d+58.123456;'Vtable
a,2,32
b,4,0.0
d,8,0.0
of Vtable
'Vupdate
1,32
2,0
3,0
2,12345678.00000
3,1234567800
3,1234567832
3,1234567890.123456
of Vupdate
of Practice
[Practice] //1int a=543;
float b;
b=123.123962+a;
b=b-100;
a=b;'Vtable
a,2,543
b,4,0.0
of Vtable
'Vupdate
1,543
2,0.0
2,123.123962
2,23.123962
1,23
of Vupdate
of Practice

原文转自:http://www.ltesting.net