C++中,int型数据的取值范围是多少?

 我来答
固若老唐
2018-12-06 · 原神攻略、整活、抽卡、娱乐博主
固若老唐
采纳数:31 获赞数:16459

向TA提问 私信TA
展开全部

int型为有符号32位整数,占4个字节,取值范围在-2,147,483,648~2,147,483,647之间。

注意:int占多少个字节是由编译器决定的,ANSI标准定义int是占2个字节.

uint型为无符号32位整数,占4个字节,取值范围在0~4,294,967,295之间。

BOOL型为int型,一般认为占4个字节,取值TRUE/FALSE/ERROR。

扩展资料:

sbyte型为有符号8位整数,占1个字节,取值范围在128~127之间。

bytet型为无符号16位整数,占2个字节,取值范围在0~255之间。

short型为有符号16位整数,占2个字节,取值范围在-32,768~32,767之间。

ushort型为无符号16位整数,占2个字节,取值范围在0~65,535之间。

long型为64位有符号整数,占8个字节,取值范围在9,223,372,036,854,775,808~9,223,372,036,854,775,807之间。

ulong型为64位无符号整数,占8个字节,取值范围在0~18,446,744,073,709,551,615之间。

float型为32位单精度实数,占4个字节,取值范围3.4E+10的负38次方~3.4E+10的38次方之间。

double型为64位实数,占8个字节,取值范围1.7E+10的负308次方~1.7E+10的正308次方。

次次次蛋黄米亚
高粉答主

2018-12-17 · 说的都是干货,快来关注
知道小有建树答主
回答量:7778
采纳率:100%
帮助的人:221万
展开全部

C++中,int占用4字节,32比特,数据范围为-2147483648~2147483647[-2^31~2^31-1]。

int占用2字节,16比特,数据范围为-32768~32767[-2^15~2^15-1]。

详细解答过程,以两个字节为例:

在C中,int型数据是一个有符号的整型数据,其最高位为符号位(0表示正,1表示负)。

1个字节等价于8个二进制位,在很多计算机系统中,通常采用补码来表示带符号的数(补码系统)。

原码:最高位为符号位(0表示正,1表示负),其他位按照一般的方法来表示数的绝对值。

反码:对于一个带符号的书来说,正数的反码与其原码相同,负数的反码为其原码除符号位以外的各位按位取反。

补码:正数的补码与其原码相同,负数的补码为其反码在最低位加1。

两个字节,所以,二进制原码最大为0111 1111 1111 1111 = 2^15 - 1 = 32767。

最小为1111 1111 1111 1111 = - (2^15 - 1) = -32767。

原码中0的表示有正负之分[+0]原 = 0000 0000 0000 0000;[-0]原 =1000 0000 0000 0000。

所以二进制原码表示时,范围是 -32767 ~ -0和0~32767,因为有两个0,所以不同的数值个数一共有2^16 - 1个。

而计算机采用而进驻补码存储数据时,0的表示是唯一的:[+0] 补= [-0] 补= 0000 0000 0000 0000

此时正数编码不变,从0000 0000 0000 0000 ~ 0111 1111 1111 1111依然表示0 ~ 32767。

负数表示需依照补码规则,即-32767的补码为1000 0000 0000 0001。

所以补码中会比原码多一个编码出来,这个编码就是1000 0000 0000 0000,因为任何一个原码都不可能在转化成补码时变成1000 0000 0000 0000,所以人们规定1000 0000 0000 0000这个补码编码为-32768。

结论:int型数据占两个字节时,可表示2^16种变化,最高位为符号位,所以正负有2^15中变化,因为0也占一种,因此正负数的最大值并不对称,即该int型数据取值范围为-32768 ~ 32767。

扩展资料:

int使用方法:

定义方法:

int i;//定义整形变量i

int i=1;//定义整形变量i并初始化为1

定义常量:

const int i;//编译错误,因为常量需要给予一个初值

const int i=1;//定义常量i,值为1   

Java定义常量:

final int i=1;//定义常量i,值为1

参考资料来源:百度百科—int

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
lynodia
2006-12-10 · TA获得超过124个赞
知道答主
回答量:94
采纳率:0%
帮助的人:0
展开全部
在标准C++中的int根据不同系统占不同的字节数,多数平台上int占4个字节,所以能表示的范围就是2的32次方,楼上说的不太对,int 4应该表示
-2^16 ~ 2^16 -1 ( ^ 表示成方 )
根据不同的需要,int包括以下定义:
unsigned short int 无符号2字节短整形
short int 带符号2字节短整形 - 32768 ~ 32767
unsigned int 无符号4字节整形 0 ~ 2^32 -1
int 4字节整形
int 64 64位(8字节)整形 - 2^32 ~ 2^32 - 1
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
去年光年
2006-12-10 · 超过14用户采纳过TA的回答
知道答主
回答量:53
采纳率:0%
帮助的人:0
展开全部
short(int) 2字节 -32768~-32767
int 4 -2的31次方~2的31次方-1
unsigned(int) 4 0~2的32次方-1
long(int) 4 -2的31次方~2的31次方-1
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
vq...5@163.com
2021-04-01 · TA获得超过150个赞
知道答主
回答量:0
采纳率:0%
帮助的人:0
展开全部

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(6)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式