c#移位運算子小節 (1)
左移運算子(<<)
將第乙個運算元向左移動第二個運算元指定的位數,空出的位置補0。例如:1100100<<2=110010000,1100100左移兩位後為 1100100口口,補0後為110010000。
右移運算子(<<)
將第乙個運算元向右移動第二個運算元所指定的位數,空出的位置補0。例如:1100100>>2=0011001,1100100右移兩位後為 口口11001,補0後為0011001。
比較有意思的東西
10進製中左移一位相當於是新增乙個0,即擴大了10的一次方倍,左移兩位則是新增兩個0,即擴大了10的二次方倍;同理,2進製左移一位也是新增了乙個0,即擴大了2的一次方倍,左移兩位則是新增兩個0,擴大了2的二次方倍,那麼就有下邊的關係:
n<<1,相當於 n*2
n<<2,相當於 n*4
n<<3,相當於 n*8
n<<4,相當於 n*16
同理,右移則表述為:
n>>1,相當於 n/2
n>>2,相當於 n/4
n>>3,相當於 n/8
n>>4,相當於 n/16
C 移位運算子
int result1 66 1 正數的左移位運算規則,左移一位乘以2,右移移位除以2 左移兩位乘以4,三位乘以8,4位乘以16,右移則相反 int result2 66 1 負數的移位運算在最高位補1 運算規則和正數一樣 console.writeline 正數移位 result1 負數移位 re...
移位運算子
移位運算子不外乎就這三種 左移 帶符號右移 和 無符號右移 1 左移運算子 左移運算子 使指定值的所有位都左移規定的次數。1 它的通用格式如下所示 value num num 指定要移位值value 移動的位數。左移的規則只記住一點 丟棄最高位,0補最低位 如果移動的位數超過了該型別的最大位數,那麼...
移位運算子
二進位制運算子,包括位運算子和移位運算子,使程式設計師可以在二進位制基礎上運算元字,可以更有效的進行運算,並且可以以二進位制的形式儲存和轉換資料,是實現網路協議解析以及加密等演算法的基礎。左移 帶符號右移 和 無符號右移 左移 在數字沒有溢位的前提下,對於正數和負數,左移一位都相當於乘以2的1次方,...