Chinaunix首页 | 论坛 | 博客
  • 博客访问: 305014
  • 博文数量: 82
  • 博客积分: 2602
  • 博客等级: 少校
  • 技术积分: 660
  • 用 户 组: 普通用户
  • 注册时间: 2007-08-10 08:48
文章分类

全部博文(82)

文章存档

2008年(17)

2007年(65)

分类: C/C++

2007-09-12 12:02:04

linux系统关于各种类型长度的定义在/usr/include/limits.h文件里面。
一、整型数据
1、整型常量
(1)十进制
(2)八进制:以0开头,如0123表示八进制数123,等于十进制的83
(3)十六进制:以0x开头,如0x123表示十六进制数123,等于十进制291
2、整型变量
ANSI标准定义的整数类型
类型                    比特数              最小取值范围
[signed]int              16              -32768~32767
Unsigned [int]           16                  0~65535  
[signed] short [int]     16               -32768~32767
Unsigned short [int]     16                  0~65535
long [int]               32                   -2^31~(2^31-1)
Unsigned long [int]      32                   0~(2^32-1) 
括号里面的部分是可以省写的。
对于取值范围我们必须注意:
如果定义int i=32767,当我们对其进行加一操作希望输出32768时,它却输出-32768这就是整型数据的溢出现象,但是运行时并不报错。
二、浮点型数据,又称做实型数据
一个实型数据一般在内存中占4个字节(32位)
1、表示方法
(1)十进制小数形式,注意它由数字和小数点组成(必须有小数点)
(2)指数形式,如123e2表示123X10^2,注意字母e(或E)之前必须有数字,且e后面的指数必须为整数
2、在内存中的存放形式
实型数据是按照指数形式存储的,系统把一个实型数据分成小数部分和指数部分,分别存放小数部分采用规范化的指数方式表示。如存放3.14159
 + .314159   1
数符   小数部分          指数
+    。314159      ×  10^1
3、分类
类型        比特数       有效数字              数值范围
float       32          6~7                 -3.4X10^(-38)~3.4X10^38
double      64          15~16               -1.7X10^(-308)~1.7X10^308
long double 128         18~19               -1.2X10^(-4932)~1.2X10^(4932)
实型数据运算一定要注意有效数字问题
三、字符型数据
字符数据既可以以字符形式输出,也可以以整数形式输出。以字符形式输出时,需要先将存储单元中的ASCII码转换成相应的字符然后输出。以整数形式输出时,直接将ASCII码作为整数形式。
一个字符变量占一个字节,存放其ASCII码。
分类:
类型          比特数       数值范围
signed char    8          -128~127
unsigned       8          0~255
四、类型转换
1、将实型数据(包含单、双精度)赋值给整型变量时,舍弃实数的小数部分。
2、将整型数据赋值给单双精度变量时,数值不变,但以浮点数形式存储到变量中
3、将一个double型数据赋值给float数据时,截取其前面7位有效数字,存放到float变量的存储单元(32位)中。但应注意数值范围不能溢出
   将一个float数据赋值给double变量时,数值不变,有效位数扩展到16位,在内存中以64位存储
4、字符型数据赋值给整型变量时,由于字符只占一个字节,而整型变量为2个字节,因此将字符数据(8位)放到整型变量的低8位中。有两种情况:
(1)如果所用系统将字符处理为无符号的量或是对unsigned char型变量赋值,则将字符的低8位放到整型变量的低8位,高8位补零。
(2)如果所用系统将字符处理为有符号的(signed char),若字符最高位为0,则整型变量高8位补零;若字符最高位为1,则高8位全补1.这称为符号扩展。
5、将一个int、short、long型数据赋值给一个char型变量时,只将其低8位原封不动地送到char型变量
   将一个long型数据付给一个int型变量时,只将long型数据中的低16位原封不动地送到整型变量,这称为“截断”
6、将unsigned int型数据赋值给long int型变量时,不存在符号扩展问题,只需将高位补0即可
 
阅读(1607) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~