3 回答

TA貢獻2021條經驗 獲得超8個贊
short int 的允許數值范圍是 -32768 到 +32767
32768 超出了short int 的允許數值范圍
所以 cout<<(short) 32768 得到的結果 取決于 編譯器處理,沒有太大的道理。
---
可以用16進制輸出,看它的2進制數值
#include <iostream>
using namespace std;
#include <stdio.h>
int main()
{
short int x = 32768;
cout<<(short) 32768<<endl;
printf("0x%x %d\n",0xffff & x,x);
return 0;
}
-32768
0x8000 -32768
0x8000 -> 2進制數值 1000 0000 0000 0000
符號位1就是負數,補碼是全零。求原碼,補碼減1再求反。0 減1 不夠減,
怎么辦呢, 要從高位借1, 減1得全1,求反 得全 0 (別忘高位欠1)因而 不看符號位的原碼為 正數 0x8000
不看符號位的原碼 正數 0x8000 就是 十進制 32768
加符號就是 -32768。-- 沒有太大的道理 的 道理。

TA貢獻1817條經驗 獲得超6個贊
32768的二進制0000000000000000 1000000000000000
強制類型轉換short為1000 0000 0000 0000
因為高位為1
所以該數的補碼為 1111 1111 1111 1111 - 1 == -32768

TA貢獻1810條經驗 獲得超5個贊
應該是-(2^15),因為32768的二進制表示是0000000000000000 1000000000000000 強制類型轉換為1000000000000000
最高位為符號位
- 3 回答
- 0 關注
- 233 瀏覽
添加回答
舉報