国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

從Java中的取反號‘~’看原碼,反碼,補碼

Rainie / 2381人閱讀

摘要:首先,存儲的是有符號數,在計算機中,有符號數通常是使用補碼存儲的,也不例外。先來看看什么叫原碼,反碼,補碼。例如原反補原反補分析所以回到一開始的問題,在計算機中是以補碼存儲的。

緣起

一次在寫測試程序的時候,隨手對2取了一個反,當時代碼大意如下:

public static void main(String[] args) {
        int a = 2;
        System.out.println(~a);
    }

按照我當時的想法,覺得過程應該是這樣的:

a = 2,也就是說a的二進制位10,取反就變成了01,所以結果應該為1。

但是實際的結果值是-3,于是就被打臉了。

知識普及

那究竟是為什么結果和我預期的不一致呢?這就要從計算機常用的幾個碼說起了。首先,java存儲的是有符號數,在計算機中,有符號數通常是使用補碼存儲的,java也不例外。先來看看什么叫原碼,反碼,補碼。

原碼

原碼就是符號位加上真值的絕對值,即用第一位表示符號, 其余位表示值. 比如如果是8位二進制:

[+1]原 = 0000 0001

[-1]原 = 1000 0001

第一位是符號位. 正數符號位為0,負數為1。

反碼

正數的反碼是其本身
負數的反碼是在其原碼的基礎上,符號位不變,其余各個位取反.
例如:

[+1] = [00000001]原 = [00000001]反

[-1] = [10000001]原 = [11111110]反

補碼

正數的補碼就是其本身
負數的補碼是在反碼的基礎上+1。
例如:

[+1] = [00000001]原 = [00000001]反 = [00000001]補

[-1] = [10000001]原 = [11111110]反 = [11111111]補

分析

所以回到一開始的問題,int a = 2 a在計算機中是以補碼存儲的。

對于2這個正數來說,補碼、反碼、原碼都是相同的,又由于是數值型,在這里我先用八位bit來表示一下:

原碼:0000 0010
反碼:0000 0010

補碼:0000 0010

取反
取反過程是在補碼的基礎上進行的,由于是按位取反,無論符號位還是數值位都要取反,所以結果如下:

取反后的補碼: 1111 1101

換算為值
那么取反后的補碼的實際值是多少呢?我們需要先把他轉化為原碼,過程如下:

反碼 = 1111 1101 - 1 = 1111 1100

原碼 = 反碼符號位不變,其余取反 = 1000 0011

所以,最后的值-3

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/65713.html

相關文章

  • Java位運算符淺析

    摘要:在學習源碼中,發現有大量使用位運算符,這樣做的目的是為了節約內存開銷和加快計算效率。位運算符,這個位代表這什么位二進制位簡稱位,是二進制記數系統中表示小于的整數的符號,一般用或表示,是具有相等概率的兩種狀態中的一種。 在學習源碼中,發現有大量使用位運算符,這樣做的目的是為了節約內存開銷和加快計算效率。 位運算符,這個位代表這什么? 位:二進制位簡稱位,是二進制記數系統中表示小于2的整數...

    zhaofeihao 評論0 收藏0
  • 關于java中的強制類型轉換和二進制表示問題

    摘要:中用補碼形式表示第一位正負位,表示負,表示正。原碼一個數的二進制表示。的補碼是的補碼是占個字節,位占個字節,位所以強轉時會截斷。 showImg(https://segmentfault.com/img/bVbsydY?w=993&h=471); 1、Java中用補碼形式表示2、第一位正負位,1表示負,0表示正。3、原碼:一個數的二進制表示。 3的原碼0000...

    cyixlq 評論0 收藏0
  • 【深入淺出-JVM】(2):原碼反碼補碼

    摘要:正數用填補,負數用填補。注不同的環境填補方式可能不同低位右移溢出則舍棄該位。感謝您的耐心閱讀,如果您發現文章中有一些沒表述清楚的,或者是不對的地方,請給我留言,您的鼓勵是作者寫作最大的動力。 計算機中有補碼表示 0 0 為正數 原碼 00000000 00000000 00000000 00000000 反碼 00000000 00000000 00000000 00000000 ...

    qpwoeiru96 評論0 收藏0
  • 一文搞明白位運算、補碼反碼原碼

    摘要:我們來看一個特殊的運算反碼反碼反碼原碼。補碼為了解決反碼的問題就出現了補碼。用原碼表示為用反碼表示為用補碼表示為,表示的補碼左移一位后為,該補碼對應的反碼為該反碼對應的原碼為符號位不變,其他位取反,為,表示。 在平時看各種框架的源碼的過程中,經常會看到一些位移運算,所以作為一個Java開發者是一定掌握位移運算的。 正數位移運算 Java中有三個位移運算: :右移 >>>:無符號右移 ...

    tunny 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<