C++移位得到int型最大值
生活随笔
收集整理的這篇文章主要介紹了
C++移位得到int型最大值
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
C++里默認(rèn)int型1的二進(jìn)制表示為:
0000 0000 0000 0000 0000 0000 0000 0001如果左移31位,會得到最小值
1<<31 //會得到-2147483648,即int型最小值即
1000 0000 0000 0000 0000 0000 0000 0000因?yàn)閕nt類型是有符號的,第一位為符號位,如果是1表示負(fù)數(shù),為什么1<<31 會得到最小值,因?yàn)閕nt是使用補(bǔ)碼表示的。如果我們想得到最大值可以使用如下代碼:
cout << (1<<31)-1 << endl;//有符號int最大值 /*輸出得到: 2147483647 */補(bǔ)碼部分概念:
負(fù)數(shù)的補(bǔ)碼就是對反碼加一,而正數(shù)不變,正數(shù)的原碼反碼補(bǔ)碼是一樣的。
計(jì)算機(jī)中:
原碼和反碼表示的0有兩種形式+0和-0,而我們知道,+0和-0是相同的。
這樣,8位的原碼和反碼表示的整數(shù)的范圍就是-127+127(1111111101111111),而采用補(bǔ)碼表示的時(shí)候,00000000是+0, 即0;
10000000不再是-0,而是-128,這樣,補(bǔ)碼表示的數(shù)的范圍就是-128~+127了,不但增加了一個(gè)數(shù)得表示范圍,而且還保證了0編碼的唯一性。
轉(zhuǎn)載自:
https://segmentfault.com/q/1010000006201661?_ea=1048818
https://blog.csdn.net/studyvcmfc/article/details/7605752
總結(jié)
以上是生活随笔為你收集整理的C++移位得到int型最大值的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: batch批处理程序easyadd——追
- 下一篇: 建立带头结点的双向链表_尾插法