程式設計中的移位運算子簡單解釋

2021-07-07 09:47:31 字數 747 閱讀 5887

1.《左移 (又叫算術左移),數字的二進位制表示中符號位不進行移位。

例如 10<<2

左移2位之後是0,0000000...0000101000 ,換算成十進位制就是40.   因為【(10*2)*2 = 40】。

例如 (-10)<<2

-10的二進位制表示是 1,1111111...11110110(共三十二位,假設機器是32位機器,64位大同小異)

2.《符號左移(又叫邏輯移位),即把數字的二進位制表示中符號位不用區別對待。

整數的符號左移和左移是等價的,因為補碼左移時右側都是補0

3.右移》(又叫算術右移),數字的二進位制表示中符號位不進行移位。

例如 10>>2

右移2位之後是0,0000000...00000010 ,換算成十進位制就是2.   因為【(10/2)/2 = 2】。

例如 (-10)>>2

-10的二進位制表示是 1,1111111...11110110(共三十二位,假設機器是32位機器,64位大同小異)

4.符號右移》(又叫邏輯移位)即把數字的二進位制表示中符號位不用區別對待。

例如 10>>>2 (正整數的符號右移同算術右移)

例如 -10>>>2

-10的二進位制表示是 1,1111111...11110110(共三十二位,假設機器是32位機器,64位大同小異)

邏輯右移兩位之後是0,011111...11111101

,換算成十進位制是1073741821 所以(-10)<<<2 = 1073741821

移位運算子

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

移位運算子

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

移位運算子

位運算子的執行速度要快於算術運算子,用位運算子代替算數符會加快程式執行速度。移位運算子包括 左移 和 右移 左移運算子的作用是將乙個二進位制位的運算元按指定的移動位數向左移動,移出位被丟棄,右邊的空位一律補0 右移運算子的作用是將乙個二進位制位的運算元按指定的移動位數向右移動,移出位被丟棄,左邊的空...