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


 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 。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM