※ 引述《final01 (牛頓運動定律)》之銘言:
: 開發平台(Platform): (Ex: Win10, Linux, ...)
: Linux
: 編譯器(Ex: GCC, clang, VC++...)+目標環境(跟開發平台不同的話需列出)
: GCC
: 額外使用到的函數庫(Library Used): (Ex: OpenGL, ...)
: 問題(Question):
: #include <stdio.h>
: void print_x(unsigned long x)
: {
: printf("=> 0x%lx\n",x);
: }
: int main()
: {
: print_x(0x80000000);
: print_x((1<<31));
: }
: 想問為何同樣是數字一個不會overflow 一個會??
: 餵入的資料(Input):
: 0x80000000
: 1<<31
我猜測你平台的 long 是 64bit。
0x80000000 的 type 是 unsigned int, 所以是 2147483648。
1<<31 運算後結果 0x80000000 的 type 是 int, 所以是 -2147483648。
很奇怪, 一個是 unsigned int, 一個卻是 int 是吧!
把 int -2147483648 傳給 unsigned long 時, 16 進位便是 0xffffffff80000000,
而不是 80000000。