摘要:首先,存儲的是有符號數(shù),在計(jì)算機(jī)中,有符號數(shù)通常是使用補(bǔ)碼存儲的,也不例外。先來看看什么叫原碼,反碼,補(bǔ)碼。例如原反補(bǔ)原反補(bǔ)分析所以回到一開始的問題,在計(jì)算機(jī)中是以補(bǔ)碼存儲的。
緣起
一次在寫測試程序的時(shí)候,隨手對2取了一個(gè)反,當(dāng)時(shí)代碼大意如下:
public static void main(String[] args) { int a = 2; System.out.println(~a); }
按照我當(dāng)時(shí)的想法,覺得過程應(yīng)該是這樣的:
a = 2,也就是說a的二進(jìn)制位10,取反就變成了01,所以結(jié)果應(yīng)該為1。
但是實(shí)際的結(jié)果值是-3,于是就被打臉了。
知識普及那究竟是為什么結(jié)果和我預(yù)期的不一致呢?這就要從計(jì)算機(jī)常用的幾個(gè)碼說起了。首先,java存儲的是有符號數(shù),在計(jì)算機(jī)中,有符號數(shù)通常是使用補(bǔ)碼存儲的,java也不例外。先來看看什么叫原碼,反碼,補(bǔ)碼。
原碼原碼就是符號位加上真值的絕對值,即用第一位表示符號, 其余位表示值. 比如如果是8位二進(jìn)制:
[+1]原 = 0000 0001
[-1]原 = 1000 0001
第一位是符號位. 正數(shù)符號位為0,負(fù)數(shù)為1。
反碼正數(shù)的反碼是其本身
負(fù)數(shù)的反碼是在其原碼的基礎(chǔ)上,符號位不變,其余各個(gè)位取反.
例如:
[+1] = [00000001]原 = [00000001]反
[-1] = [10000001]原 = [11111110]反
補(bǔ)碼正數(shù)的補(bǔ)碼就是其本身
負(fù)數(shù)的補(bǔ)碼是在反碼的基礎(chǔ)上+1。
例如:
[+1] = [00000001]原 = [00000001]反 = [00000001]補(bǔ)
[-1] = [10000001]原 = [11111110]反 = [11111111]補(bǔ)
分析所以回到一開始的問題,int a = 2 a在計(jì)算機(jī)中是以補(bǔ)碼存儲的。
對于2這個(gè)正數(shù)來說,補(bǔ)碼、反碼、原碼都是相同的,又由于是數(shù)值型,在這里我先用八位bit來表示一下:
原碼:0000 0010
反碼:0000 0010
補(bǔ)碼:0000 0010
取反
取反過程是在補(bǔ)碼的基礎(chǔ)上進(jìn)行的,由于是按位取反,無論符號位還是數(shù)值位都要取反,所以結(jié)果如下:
取反后的補(bǔ)碼: 1111 1101
換算為值
那么取反后的補(bǔ)碼的實(shí)際值是多少呢?我們需要先把他轉(zhuǎn)化為原碼,過程如下:
反碼 = 1111 1101 - 1 = 1111 1100
原碼 = 反碼符號位不變,其余取反 = 1000 0011
所以,最后的值-3
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/65713.html
摘要:在學(xué)習(xí)源碼中,發(fā)現(xiàn)有大量使用位運(yùn)算符,這樣做的目的是為了節(jié)約內(nèi)存開銷和加快計(jì)算效率。位運(yùn)算符,這個(gè)位代表這什么位二進(jìn)制位簡稱位,是二進(jìn)制記數(shù)系統(tǒng)中表示小于的整數(shù)的符號,一般用或表示,是具有相等概率的兩種狀態(tài)中的一種。 在學(xué)習(xí)源碼中,發(fā)現(xiàn)有大量使用位運(yùn)算符,這樣做的目的是為了節(jié)約內(nèi)存開銷和加快計(jì)算效率。 位運(yùn)算符,這個(gè)位代表這什么? 位:二進(jìn)制位簡稱位,是二進(jìn)制記數(shù)系統(tǒng)中表示小于2的整數(shù)...
摘要:中用補(bǔ)碼形式表示第一位正負(fù)位,表示負(fù),表示正。原碼一個(gè)數(shù)的二進(jìn)制表示。的補(bǔ)碼是的補(bǔ)碼是占個(gè)字節(jié),位占個(gè)字節(jié),位所以強(qiáng)轉(zhuǎn)時(shí)會截?cái)唷? showImg(https://segmentfault.com/img/bVbsydY?w=993&h=471); 1、Java中用補(bǔ)碼形式表示2、第一位正負(fù)位,1表示負(fù),0表示正。3、原碼:一個(gè)數(shù)的二進(jìn)制表示。 3的原碼0000...
摘要:正數(shù)用填補(bǔ),負(fù)數(shù)用填補(bǔ)。注不同的環(huán)境填補(bǔ)方式可能不同低位右移溢出則舍棄該位。感謝您的耐心閱讀,如果您發(fā)現(xiàn)文章中有一些沒表述清楚的,或者是不對的地方,請給我留言,您的鼓勵(lì)是作者寫作最大的動力。 計(jì)算機(jī)中有補(bǔ)碼表示 0 0 為正數(shù) 原碼 00000000 00000000 00000000 00000000 反碼 00000000 00000000 00000000 00000000 ...
摘要:我們來看一個(gè)特殊的運(yùn)算反碼反碼反碼原碼。補(bǔ)碼為了解決反碼的問題就出現(xiàn)了補(bǔ)碼。用原碼表示為用反碼表示為用補(bǔ)碼表示為,表示的補(bǔ)碼左移一位后為,該補(bǔ)碼對應(yīng)的反碼為該反碼對應(yīng)的原碼為符號位不變,其他位取反,為,表示。 在平時(shí)看各種框架的源碼的過程中,經(jīng)常會看到一些位移運(yùn)算,所以作為一個(gè)Java開發(fā)者是一定掌握位移運(yùn)算的。 正數(shù)位移運(yùn)算 Java中有三個(gè)位移運(yùn)算: :右移 >>>:無符號右移 ...
閱讀 3546·2021-11-18 10:02
閱讀 3115·2019-08-29 18:34
閱讀 3404·2019-08-29 17:00
閱讀 434·2019-08-29 12:35
閱讀 761·2019-08-28 18:22
閱讀 1939·2019-08-26 13:58
閱讀 1675·2019-08-26 10:39
閱讀 2682·2019-08-26 10:11