1. 程式人生 > >INT_MIN和INT_MAX註意事項 //C++

INT_MIN和INT_MAX註意事項 //C++

一個 個數 c++ 編譯 pre turn 這不 return fine

 1 #include<iostream>
 2 #include<cmath>
 3 using namespace std;
 4 int main()
 5 {
 6     //int -2147483648~2147483647    2^32 
 7     cout << INT_MIN <<endl;
 8     cout << INT_MAX <<endl;
 9     //unsigned int 4294967295        2^32    
10     cout << UINT32_MAX <<endl;
11 //long long 9223372036854775807 2^64 12 cout << LONG_LONG_MAX <<endl; 13 cout << LONG_LONG_MIN <<endl; 14 //unsigned long long 18446744073709551615 2^64 15 cout << UINT64_MAX <<endl; 16 return 0; 17 }

結果:

1 -2147483648
2 2147483647 3 4294967295 4 9223372036854775807 5 -9223372036854775808 6 18446744073709551615

INT_MIN在標準頭文件limits.h中定義。

1 #define INT_MAX 2147483647
2 #define INT_MIN (-INT_MAX - 1)//這裏沒有簡單地將INT_MIN賦值成-2147483647,是因為-2147483648對於編譯器而言是個表達式,而2147483648對於32-bit整數是無法表示的,
所以經過這個表達式的結果是未定義的。在GCC上直接寫-2147483648後,編譯器給出了警告,說結果是unsigned。

在C/C++語言中,不能夠直接使用-2147483648來代替最小負數,因為這不是一個數字,而是一個表達式。表達式的意思是對整數21473648取負,但是2147483648已經溢出了int的上限,所以定義為(-INT_MAX -1)。

C中int類型是32位的,範圍是-2147483648到2147483647 。
(1)最輕微的上溢是INT_MAX + 1 :結果是 INT_MIN;
(2)最嚴重的上溢是INT_MAX + INT_MAX :結果是-2;
(3)最輕微的下溢是INT_MIN - 1:結果是是INT_MAX;
(4)最嚴重的下溢是INT_MIN + INT_MIN:結果是0 。

INT_MIN和INT_MAX註意事項 //C++