int的最小值是怎么来的?按书上所说的 最高位为表示符号 按照它的意思就是说 当int为最小时候 它的补码就应该为 1111 1111 1111 1111
可为什么得到的却是-32768呢?? 我按照取反再加1的原则 逆的化回去
那就是先 减1再取反 得到0000 0000 0000 0001 ??? 糊涂啊~!!~??
什么正0 负0啊 说的通俗点好吗???
int的最小值是怎么来的呀?
答案:2 悬赏:50
解决时间 2021-02-20 11:15
- 提问者网友:护她一生,唯爱
- 2021-02-20 00:48
最佳答案
- 二级知识专家网友:偏爱自由
- 2021-02-20 01:41
一个是正0:0x0000 0000 0000 0000
一个是负0:0x1000 0000 0000 0000 (负0就是-32768)
所以最小的应当是:0x1000 0000 0000 0000
而不是0x1111 1111 1111 1111
一个是负0:0x1000 0000 0000 0000 (负0就是-32768)
所以最小的应当是:0x1000 0000 0000 0000
而不是0x1111 1111 1111 1111
全部回答
- 1楼网友:一池湖水
- 2021-02-20 02:55
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了,但是同时也多出来一个
我要举报
如以上问答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯