移位運算子「 」 「 」和「 」的詮釋

2021-09-01 08:53:34 字數 1229 閱讀 7503

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

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

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

在移位運算時,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;

位運算子和移位運算子

golang中有3個位運算 按位與 按位或 按位異或 按位與 兩位全為1,結果為1,否則為0 按位或 兩位有乙個為1,結果為1,否則為0 按位異或 兩位乙個為0,乙個為1,結果為1,否則為0 例如 2 3 2 2的補碼0000 0010 3的補碼0000 0011 2 3 0000 0010 2 2...

移位運算子

移位運算子不外乎就這三種 左移 帶符號右移 和 無符號右移 1 左移運算子 左移運算子 使指定值的所有位都左移規定的次數。1 它的通用格式如下所示 value num num 指定要移位值value 移動的位數。左移的規則只記住一點 丟棄最高位,0補最低位 如果移動的位數超過了該型別的最大位數,那麼...

移位運算子

二進位制運算子,包括位運算子和移位運算子,使程式設計師可以在二進位制基礎上運算元字,可以更有效的進行運算,並且可以以二進位制的形式儲存和轉換資料,是實現網路協議解析以及加密等演算法的基礎。左移 帶符號右移 和 無符號右移 左移 在數字沒有溢位的前提下,對於正數和負數,左移一位都相當於乘以2的1次方,...