詳解原碼、反碼與補碼存儲與大小
詳解原碼、反碼與補碼存儲與大小
原碼:
如果機器字長為N個bit,那么一個數(shù)的原碼就是N位二進制數(shù),最高位
是符號位,1代表負數(shù),0代表正數(shù)。
反碼:
正數(shù)的反碼就是原碼,負數(shù)的反碼就是符號位不變,其他取反。
補碼:
正數(shù)的補碼與其原碼相同;負數(shù)的補碼是在其反碼的末位加1。
(計算機中的數(shù)都是以補碼形式存儲的)
補碼的形式是為了進行正負數(shù)二進制的加減操作
char為1個字節(jié),8個bit位,看看內(nèi)存中是怎么存儲的
十六進制 二進制(補碼) 反碼 原碼 實際值 char a = 127; //7f 0111 1111 127 char b = 128; //80 1000 0000 0111 1111 1000 0000 -128 char c = -128; //80 1000 0000 0111 1111 1000 0000 -128 char d = -1; //ff 1111 1111 1111 1110 1000 0001 -1
-128可能大家會有疑問,1000 0000是負數(shù),按補碼反碼原碼的方式往回推減一為0111 1111,取反1000 0000為128,因為是負數(shù)所以就是-128.
所以signed char的最大值為127,最小值為-128.
unsigned是無符號的意思,就是沒有符號位。
unsigned char e = 256; //00 0000 0000 0 unsigned char f = -1; //ff 1111 1111 255 unsigned char g = 255; //ff 1111 1111 255
因為沒有符號位,所以原反補碼都一樣,為什么-1的值為255呢,-1的原碼是0000 0001(沒符號位),反碼1111 1110,補碼
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關文章
C++實現(xiàn)LeetCode(158.用Read4來讀取N個字符之二 - 多次調用)
這篇文章主要介紹了C++實現(xiàn)LeetCode(158.用Read4來讀取N個字符之二 - 多次調用),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-07-07
c++類成員函數(shù)如何做函數(shù)參數(shù)
這篇文章主要介紹了c++類成員函數(shù)如何做函數(shù)參數(shù)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-11-11
C++數(shù)組放在main函數(shù)內(nèi)外的區(qū)別
大家好,本篇文章主要講的是C++數(shù)組放在main函數(shù)內(nèi)外的區(qū)別,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下2022-01-01

