移位運算子詳解

2022-06-02 08:24:01 字數 1081 閱讀 1623

移位運算子就是在二進位制的基礎上對數字進行平移。

按照平移的方向和填充數字的規則分為三種:

<<(左移)、>>(帶符號右移)和》(無符號右移)。

在移位運算時,byte、short和char型別移位後的結果會變成int型別,對於byte、short、char和int進行移位時,規定實際移動的次數是移動次數和32的餘數,也就是移位33次和移位1次得到的結果相同。移動long型的數值時,規定實際移動的次數是移動次數和64的餘數,也就是移動66次和移動2次得到的結果相同。

三種移位運算子的移動規則和使用如下所示:

《運算規則:

按二進位制形式把所有的數字向左移動對應的位數,高位移出(捨棄),低位的空位補零。

語法格式:

需要移位的數字 << 移位的次數

例如: 3 << 2,則是將數字3左移2位

計算過程:

3 << 2

首先把3轉換為二進位制數字

0000 0000 0000 0000 0000 0000 0000 0011,

然後把該數字高位(左側)的兩個零移出,其他的數字都朝左平移2位,最後在低位(右側)的兩個空位補零。則得到的最終結果是

0000 0000 0000 0000 0000 0000 0000 1100,

則轉換為十進位制是12.

>>運算規則:

按二進位制形式把所有的數字向右移動對應位數,低位移出(捨棄),

高位的空位補符號位,即正數補零,負數補1.

語法格式:

需要移位的數字 >> 移位的次數

例如11 >> 2,則是將數字11右移2位

計算過程:

11的二進位制形式為:

0000 0000 0000 0000 0000 0000 0000 1011,

然後把低位的最後兩個數字移出,因為該數字是正數,所以在高位補零。則得到的最終

結果是:

0000 0000 0000 0000 0000 0000 0000 0010.

轉換為十進位制是2.

>>>運算規則:

按二進位制形式把所有的數字向右移動對應位數,低位移出(捨棄),高位的空位補零。

無論正數還是負數都在高位插入0;

Java位運算子詳解

按位與運算子 參加運算的兩個資料,按二進位制位進行 與 運算。運算規則 0 0 0 0 1 0 1 0 0 1 1 1 即 兩位同時為 1 結果才為 1 否則為0 例如 3 5 即 0000 0011 0000 0101 0000 0001 因此,3 5的值得1。另,負數按補碼形式參加按位與運算。與...

運算子過載

一 運算子過載的概念 運算子過載允許把標準運算子重定義,使之對指定型別的物件執行指定的操作。注意 1 一般地,運算子過載函式由關鍵字operator和要過載的運算子組成,對於用字母表示的運算子,例如new和delete,在關鍵字和運算子之間至少有乙個空格。對於其它運算子,空格可選。2 過載運算子不准...

c語言邏輯運算子詳解

邏輯運算子 包括 1。邏輯與 2。邏輯或 3。邏輯非 邏輯運算子用於對包含關係運算子的表示式進行合併或取非 對於使用邏輯運算子的表示式,返回0表示 假 返回1表示 真 關於邏輯運算子的解釋 請注意 任何使用兩個字元做符號的運算子,兩字元之間不應有空格,即將 寫成 是錯誤的。假設乙個程式在同時滿足條件...