计算机术语int,整型(计算机语言)_百度百科

计算机中的一个基本的专业术语,指没有小数部分的数据。整型可以用十进制,十六进制或八进制符号指定,前面可以加上可选的符号(- 或者 +)。包括整型常量和整型变量,整型变量又包括短整型、基本整型、长整型,它们都分为有符号和无符号两种版本,是一种智能的计算方式。

中文名

整型

外文名

integer

注意1

PHP 不支持无符号整数主词条

整型量

注意2

PHP 中没有整除的运算符

衍生数据类型

长整型long int、 短整型short int

整型定义

编辑

语音

一个 integer 是集合 Z = {..., -2, -1, 0, 1, 2, ...} 中的一个数。【以PHP语言为例】

参见:任意长度整数 / GMP,精度数学库 / BCMath。

整型语法

编辑

语音

整型值可以用十进制,十六进制或八进制符号指定,前面可以加上可选的符号(- 或者 +)。

如果用八进制符号,数字前必须加上 0(零),用十六进制符号数字前必须加上 0x。

例. 整数文字表达:【以PHP语言为例】

$a=1234;#

十进制数

$a=-123;#一个负数

$a=0123;#

八进制数(等于十进制的83)

$a=0x1A;#

十六进制数(等于十进制的26)

?>

在字面上,整型变量正式的结构可以为:

decimal:[1-9][0-9]*

|0

hexadecimal:0[xX][0-9a-fA-F]+

octal:0[0-7]+

integer:[+-]?

decimal

|[+-]?hexadecimal

|[+-]?octal

?>

----------------------------------------------------------------------------------------------------------

注意:整型数的字长和平台有关,尽管通常最大值是大约二十亿(32 位有符号)。

另:PHP 不支持无符号整数。

分类

整型整型常量

编辑

语音

整型八进制整常数

必须以0开头,即以0作为八进制数的前缀。数码取值为0~7。八进制数通常是无符号数。

以下各数是合法的八进制数:

015(十进制为13) 0101(十进制为65) 0177777(十进制为65535)

以下各数不是合法的八进制数:

256(无前缀0) 0382(包含了非八进制数码) -0127(出现了负号)

整型十六进制整常数

十六进制整常数的前缀为0X或0x。其数码取值为0~9,A~F或a~f。

以下各数是合法的十六进制整常数:

0X2A(十进制为42) 0XA0 (十进制为160) 0XFFFF (十进制为65535)

以下各数不是合法的十六进制整常数:

5A (无前缀0X) 0X3H (含有非十六进制数码)

整型十进制整常数

十进制整常数没有前缀。其数码为0~9。

以下各数是合法的十进制整常数:

237 -568 65535 1627

以下各数不是合法的十进制整常数:

023 (不能有前导0) 23D (含有非十进制数码)

在程序中是根据前缀来区分各种进制数的。因此在书写常数时不要把前缀弄错造成结果不正确。例如,数组int power_of_10[4]={0001,0010,0100,1000}的初值会被解释为{1,8,64,1000}。

整型整型常数的后缀

在16位字长的机器上,基本整型的长度也为16位,因此表示的数的范围也是有限定的。十进制无符号整常数的范围为0~65535,有符号数为-32768~+32767。八进制无符号数的表示范围为0~0177777。十六进制无符号数的表示范围为0X0~0XFFFF或0x0~0xFFFF。如果使用的数超过了上述范围,就必须用长整型数来表示。长整型数是用后缀“L”或“l”来表示的。例如:[1]

十进制长整常数 158L (十进制为158) 358000L (十进制为-358000)

八进制长整常数 012L (十进制为10) 077L (十进制为63) 0200000L (十进制为65536)

十六进制长整常数 0X15L (十进制为21) 0XA5L (十进制为165) 0X10000L (十进制为65536)

长整数158L和基本整常数158在数值上并无区别。但对158L,因为是长整型量,C编译系统将为它分配4个字节存储空间。而对158,因为是基本整型,根据计算机的内部字长和编译器的版本分配2或4个字节的存储空间。因此在运算和输出格式上要予以注意,避免出错。对长整型都表示不了的大数,某些编译器规定可有64位整常数表示,后缀为“LL”或“ll”。有时,因为特殊需要,可能要对短整型进行特殊标记,只有部分编译器支持短整型的后缀“S”或“s”。无符号数也可用后缀表示,整型常数的无符号数的后缀为“U”或“u”。例如:358u,0x38Au,235Lu均为无符号数。前缀,后缀可同时使用以表示各种类型的数。如0XA5Lu表示十六进制无符号长整数A5,其十进制为165。

整型整型变量

编辑

语音

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

整型基本型

类型说明符为int,根据计算机的内部字长和编译器的版本,在内存中可能占2或4个字节(通常分别在16位机和32位机上),其取值为基本整常数。

整型短整型

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

整型长整型

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

4.64位整型(非ANSI标准)

类型说明符为__int64、long long int或long long,在内存中占8个字节,其取值为64位整常数。

整型无符号型

类型说明符为unsigned。它可以单独使用代表unsigned int,也可以作为前缀,都表示无符号整数,即永远为非负的整型变量,大于0的数据范围约扩大为原来的2倍。各种无符号类型量所占的内存空间字节数与相应的有符号类型量相同。但由于省去了符号位,故不能表示负数。下表列出了C++中各类整型量所分配的内存字节数及数的表示范围。

整型对比

类型说明符数的范围分配字节数备注

short-32768~32767■■

short int-32768~32767■■

signed int-2147483648~2147483647■■■■

unsigned int0~4294967295■■■■

long int-2147483648~2147483647■■■■

unsigned long0~4294967295■■■■

long long-9223372036854775808~9223372036854775807■■■■■■■■

unsigned long long0~18446744073709551615■■■■■■■■

__int128-0x80000000000000000000000000000000~0x7fffffffffffffffffffffffffffffff■■■■■■■■■■■■■■■■C++14及以上支持,但暂不支持cin、cout输入输出

unsigned __int1280~__INT128_MAX*2+1■■■■■■■■■■■■■■■■同上

整型整数溢出

编辑

语音

如果你指定一个数超出了 integer 的范围,将会被解释为 float。同样如果你执行的运算结果超出了 integer 范围,也会返回 float。【以PHP语言为例】

$large_number=1;

var_dump($large_number);

//输出为:int(1)

$large_number=1;

var_dump($large_number);

//输出为:

float(1)

//同样也适用于

十六进制表示的整数:

var_dump(0x80000000);

//输出为:float(1)

$million=1000000;

$large_number=50000*$million;

var_dump($large_number);

//输出为:float(50000000)

?>

PHP 中没有整除的运算符。1/2 产生出浮点数 0.5。您可以总是舍弃小数部分,或者使用 round() 函数。

var_dump(25/7);//float(3.5714)

var_dump((int)(25/7));//int(3)

var_dump(round(25/7));//

float(4)

?>

整型转换为整型

编辑

语音

要明示地将一个值转换为 integer,用 (int) 或 (integer) 强制转换。不过大多数情况下都不需要强制转换,因为当运算符,函数或流程控制需要一个 integer 参数时,值会自动转换。您还可以通过函数 intval() 来将一个值转换成整型。

整型从布尔值转换

FALSE 将产生出0(零),TRUE 将产生出1(壹)。

整型从浮点数转换

当从浮点数转换成整数时,数字将被取整(丢弃小数位)。

注意:如果浮点数超出了整数范围(通常为 +/- 2.15e+9 = 2^31),则结果不确定,因为没有足够的精度使浮点数给出一个确切的整数结果。在此情况下没有警告,甚至没有任何通知!

注:在 Linux 下返回结果是最小负数(-214748),而在 Windows 下返回结果是零(0)。

【以下以C/C++语言为例,陈述一下整型的知识】:

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,部分编译器还扩展了一些更长的整型,比如long long和__int64, C99中增加了long long和unsigned long long;

f int 的长度与机器字长相同,16位的编译器上int长16位,32位的编译器上int长32位;

g short int的长度小于等于int 的长度,注意它们可能长度相等,这取决于编译器;

h long int 的长度大于等于int 的长度,注意它们可能长度相等,这取决于编译器;

i.char 的长度应当可以包容得下一个字符,大部分系统中就是一个字节,而有的系统中可能是4个字节,因为这些系统中一个字符需要四个字节来描述;

j.char 的正负取决于编译器,而编译器的决定取决于操作系统,在不同的编译器中char可能等同于signed char,也可能等同于unsigned char;

整型总结

编辑

语音

a. 出于效率考虑,应该尽量使用int和unsigned int;

b. 当需要指定容量的整型时,不应该直接使用short、int、long等,因为在不同的编译器上它们的容量不相同。此时应该定义它们相应的宏或类型,比如在VC++6.0中,可以如下定义:

[Copy to clipboard]CODE:

typedef unsigned char UBYTE;

typedef signed char SBYTE;

typedef unsigned short int UWORD;

typedef signed short int SWORD;

typedef unsigned int UDWORD;

typedef signed int SDWORD;

typedef unsigned __int64 UQWORD;

typedef signed __int64 SQWORD;

然后在代码中使用UBYTE、SBYTE、UWORD等,这样当代码移植的时候只需要修改相应的类型即可。

定义自己的类型虽然在代码移植的时候只需要修改一处即可,但仍然属于源代码级别的修改,所以 C++ 2.0 中将这些类型定义在模板中,可以做到代码移植时无需修改代码。

c. 在定义char时,一定要加上signed或unsigned,因为它的正负在不同的编译器上并不相同。

d. 不要想当然的以为char是1字节长,因为它的长度在不同的编译器上并不相同。

参考资料

1.

索明何,邢海霞,方伟骏.C语言程序设计:机械工业出版社,2016.2

2.

谭浩强.C程序设计(第4版):清华大学出版社,2010.6

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值