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 × 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即可
阅读(1988) | 评论(0) | 转发(0) |