C语言中长整形4个字节的数据范围是多少?
2个回答
展开全部
1个字节是8bit,4个字节就是32bit,所以表示范围就是32个0到32个1.
如果是无符号数,unsigned类型,那么最小就是0,最大就是(2的32次方)-1;
(为什么是2的32次方-1,以1个8位数来看,0000 0001表示1,是2的0次方;0000 0010表示2,是2的1次方,那么1000 0000,最高位是2的7次方,所以1111 1111就等于2的8次方-1,同理32个1就表示2的32次方-1)
如果是有符号数,那么最高位就是符号位,其他31位是数值位,那么最大正数就是(2的31次方)-1;而负数是补码表示的,也就是反码+1,所以1000..00(31个0)就表示-2的31次方,所以最小数就是-2的31次方。
所以对于4个字节的长整数,
unsigned的范围就是 0 到 2^32 -1
有符号数的范围就是 -2^31 到 2^31-1
如果是无符号数,unsigned类型,那么最小就是0,最大就是(2的32次方)-1;
(为什么是2的32次方-1,以1个8位数来看,0000 0001表示1,是2的0次方;0000 0010表示2,是2的1次方,那么1000 0000,最高位是2的7次方,所以1111 1111就等于2的8次方-1,同理32个1就表示2的32次方-1)
如果是有符号数,那么最高位就是符号位,其他31位是数值位,那么最大正数就是(2的31次方)-1;而负数是补码表示的,也就是反码+1,所以1000..00(31个0)就表示-2的31次方,所以最小数就是-2的31次方。
所以对于4个字节的长整数,
unsigned的范围就是 0 到 2^32 -1
有符号数的范围就是 -2^31 到 2^31-1
展开全部
有些是有差别的,具体要看编译器
char/signed
char/unsigned
char:
1个字节;
char*(即指针变量):
2个字节(16位编译器)
4个字节(32位编译器)
8个字节(64位编译器)
short
int:
2个字节
int/unsigned
int:
2个字节(16位编译器)
4个字节(32/64位编译器)
long
int:
4个字节
float:
4个字节
double:
8个字节
long/unsigned
long:
4个字节(16/32位编译器)
8个字节(64位编译器)
long
long:
8个字节
指针4个字节(32位编译器)
char/signed
char/unsigned
char:
1个字节;
char*(即指针变量):
2个字节(16位编译器)
4个字节(32位编译器)
8个字节(64位编译器)
short
int:
2个字节
int/unsigned
int:
2个字节(16位编译器)
4个字节(32/64位编译器)
long
int:
4个字节
float:
4个字节
double:
8个字节
long/unsigned
long:
4个字节(16/32位编译器)
8个字节(64位编译器)
long
long:
8个字节
指针4个字节(32位编译器)
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询