计算机中的一个基本的专业术语,指没有小数部分的数据。整型可以用十进制,十六进制或八进制符号指定,前面可以加上可选的符号(-或者+)。包括整型常量和整型变量,整型变量又包括短整型、基本整型、长整型,它们都分为有符号和无符号两种版本,是一种智能的计算方式。
定义
一个integer是集合Z={...,-2,-1,0,1,2,...}中的一个数。
参见:任意长度整数/GMP,浮点数和任意精度数学库/BCMath。
语法
整型值可以用十进制,十六进制或八进制符号指定,前面可以加上可选的符号(-或者+)。
如果用八进制符号,数字前必须加上0(零),用十六进制符号数字前必须加上0x。
例.整数文字表达:
在字面上,整型变量正式的结构可以为:
----------------------------------------------------------------------------------------------------------
注意:整型数的字长和平台有关,尽管通常最大值是大约二十亿(32位有符号)。
另:PHP不支持无符号整数。
分类
整型常量八进制整常数
必须以0开头,即以0作为八进制数的前缀。数码取值为0~7。八进制数通常是无符号数。
以下各数是合法的八进制数:
(十进制为13)(十进制为65)(十进制为)
以下各数不是合法的八进制数:
(无前缀0)(包含了非八进制数码)-(出现了负号)
十六进制整常数
十六进制整常数的前缀为0X或0x。其数码取值为0~9,A~F或a~f。
以下各数是合法的十六进制整常数:
0X2A(十进制为42)0XA0(十进制为)0XFFFF(十进制为)
以下各数不是合法的十六进制整常数:
5A(无前缀0X)0X3H(含有非十六进制数码)
十进制整常数
十进制整常数没有前缀。其数码为0~9。
以下各数是合法的十进制整常数:
-5681627
以下各数不是合法的十进制整常数:
(不能有前导0)23D(含有非十进制数码)
在程序中是根据前缀来区分各种进制数的。因此在书写常数时不要把前缀弄错造成结果不正确。例如,数组intpower_of_10[4]={,,,}的初值会被解释为{1,8,64,}。
整型常数的后缀
在16位字长的机器上,基本整型的长度也为16位,因此表示的数的范围也是有限定的。十进制无符号整常数的范围为0~,有符号数为-~+。八进制无符号数的表示范围为0~。十六进制无符号数的表示范围为0X0~0XFFFF或0x0~0xFFFF。如果使用的数超过了上述范围,就必须用长整型数来表示。长整型数是用后缀“L”或“l”来表示的。例如:1
十进制长整常数L(十进制为)L(十进制为-)
八进制长整常数L(十进制为10)L(十进制为63)L(十进制为)
十六进制长整常数0X15L(十进制为21)0XA5L(十进制为)0X0L(十进制为)
长整数L和基本整常数在数值上并无区别。但对L,因为是长整型量,C编译系统将为它分配4个字节存储空间。而对,因为是基本整型,根据计算机的内部字长和编译器的版本分配2或4个字节的存储空间。因此在运算和输出格式上要予以注意,避免出错。对长整型都表示不了的大数,某些编译器规定可有64位整常数表示,后缀为“LL”或“ll”。有时,因为特殊需要,可能要对短整型进行特殊标记,只有部分编译器支持短整型的后缀“S”或“s”。无符号数也可用后缀表示,整型常数的无符号数的后缀为“U”或“u”。例如:u,0x38Au,Lu均为无符号数。前缀,后缀可同时使用以表示各种类型的数。如0XA5Lu表示十六进制无符号长整数A5,其十进制为。
整型变量
整型变量可分为以下几类:2
基本型
类型说明符为int,根据计算机的内部字长和编译器的版本,在内存中可能占2或4个字节(通常分别在16位机和32位机上),其取值为基本整常数。
短整型
类型说明符为shortint或short,在内存中占2个字节,其取值为短整常数。
长整型
类型说明符为longint或long,在内存中占4个字节,其取值为长整常数。
4.64位整型(非ANSI标准)
类型说明符为__int64、longlongint或longlong,在内存中占8个字节,其取值为64位整常数。
无符号型
类型说明符为unsigned。它可以单独使用代表unsignedint,也可以作为前缀,都表示无符号整数,即永远为非负的整型变量,大于0的数据范围约扩大为原来的2倍。各种无符号类型量所占的内存空间字节数与相应的有符号类型量相同。但由于省去了符号位,故不能表示负数。下表列出了C++中各类整型量所分配的内存字节数及数的表示范围。
对比
类型说明符
数的范围
分配字节数
备注
short
-~
■■
shortint
-~
■■
signedint
-~
■■■■
unsignedint
0~
■■■■
longint
-~
■■■■
unsignedlong
0~
■■■■
longlong-~■■■■■■■■unsignedlonglong0~■■■■■■■■__int-0x~0x7fffffffffffffffffffffffffffffff■■■■■■■■■■■■■■■■C++14及以上支持,但暂不支持cin、cout输入输出unsigned__int0~__INT_MAX*2+1■■■■■■■■■■■■■■■■同上
整数溢出
如果你指定一个数超出了integer的范围,将会被解释为float。同样如果你执行的运算结果超出了integer范围,也会返回float。
PHP中没有整除的运算符。1/2产生出浮点数0.5。您可以总是舍弃小数部分,或者使用round()函数。
转换为整型
要明示地将一个值转换为integer,用(int)或(integer)强制转换。不过大多数情况下都不需要强制转换,因为当运算符,函数或流程控制需要一个integer参数时,值会自动转换。您还可以通过函数intval()来将一个值转换成整型。
从布尔值转换
FALSE将产生出0(零),TRUE将产生出1(壹)。
从浮点数转换
当从浮点数转换成整数时,数字将被取整(丢弃小数位)。
注意:如果浮点数超出了整数范围(通常为+/-2.15e+9=2^31),则结果不确定,因为没有足够的精度使浮点数给出一个确切的整数结果。在此情况下没有警告,甚至没有任何通知!
注:在Linux下返回结果是最小负数(-),而在Windows下返回结果是零(0)。
:
a.C/C++对整型长度的规定是为了执行效率,将int定义为机器字长可以取得最大的执行速度;
b.C/C++中整型包括:int,char和enum,C++中还包含bool类型,C99中bool是一个宏,实际为_Bool;
c.C和C++对enum的规定有所不同,这里不描述;
d.修饰整型正负的有signed和unsigned,对于int默认为signed;
e.修饰int大小的有short和long,部分编译器还扩展了一些更长的整型,比如longlong和__int64,C99中增加了longlong和unsignedlonglong;
fint的长度与机器字长相同,16位的编译器上int长16位,32位的编译器上int长32位;
gshortint的长度小于等于int的长度,注意它们可能长度相等,这取决于编译器;
hlongint的长度大于等于int的长度,注意它们可能长度相等,这取决于编译器;
i.char的长度应当可以包容得下一个字符,大部分系统中就是一个字节,而有的系统中可能是4个字节,因为这些系统中一个字符需要四个字节来描述;
j.char的正负取决于编译器,而编译器的决定取决于操作系统,在不同的编译器中char可能等同于signedchar,也可能等同于unsignedchar;
总结
a.出于效率考虑,应该尽量使用int和unsignedint;
b.当需要指定容量的整型时,不应该直接使用short、int、long等,因为在不同的编译器上它们的容量不相同。此时应该定义它们相应的宏或类型,比如在VC++6.0中,可以如下定义:
[Copytoclipboard]CODE:
typedefunsignedcharUBYTE;
typedefsignedcharSBYTE;
typedefunsignedshortintUWORD;
typedefsignedshortintSWORD;
typedefunsignedintUDWORD;
typedefsignedintSDWORD;
typedefunsigned__int64UQWORD;
typedefsigned__int64SQWORD;
然后在代码中使用UBYTE、SBYTE、UWORD等,这样当代码移植的时候只需要修改相应的类型即可。
定义自己的类型虽然在代码移植的时候只需要修改一处即可,但仍然属于源代码级别的修改,所以C++2.0中将这些类型定义在模板中,可以做到代码移植时无需修改代码。
c.在定义char时,一定要加上signed或unsigned,因为它的正负在不同的编译器上并不相同。
d.不要想当然的以为char是1字节长,因为它的长度在不同的编译器上并不相同。
本词条内容贡献者为:
闫晓东-副教授-中央民族大学信息工程学院