c语言 int的范围不是-32768~32767吗?为什么我输入了大于的数还是成立.
1个回答
展开全部
1
c语言中,int若是规定大小为两个字节,则其最小值就是-32768
2
原因
两个字节是16位,规定第一位为符号位,则其能表示的数值范围是-2^15~2^15-1,即-32768~32767。但最小值为什么是-32768,为什么不是-32767呢?
原来人们发现若是在内存中直接存放数的原码,则0000
0000
0000
0000和1000
0000
0000
0000分别表示+0和-0,其值都是0,用两个值表示同一个值,这样太浪费空间了。
于是人们最后决定在内存中存放数的补码,这样+0和-0的存放形式就都是0000
0000
0000
0000了,但是同时也多出来一个1111
1111
1111
1111,它并不是任何一个数的补码,于是将其规定为-32768。
c语言中,int若是规定大小为两个字节,则其最小值就是-32768
2
原因
两个字节是16位,规定第一位为符号位,则其能表示的数值范围是-2^15~2^15-1,即-32768~32767。但最小值为什么是-32768,为什么不是-32767呢?
原来人们发现若是在内存中直接存放数的原码,则0000
0000
0000
0000和1000
0000
0000
0000分别表示+0和-0,其值都是0,用两个值表示同一个值,这样太浪费空间了。
于是人们最后决定在内存中存放数的补码,这样+0和-0的存放形式就都是0000
0000
0000
0000了,但是同时也多出来一个1111
1111
1111
1111,它并不是任何一个数的补码,于是将其规定为-32768。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询