簡述位移運算子(二進位制轉換示例)

2022-03-06 12:12:31 字數 1664 閱讀 7518

位移運算子{<<(左移),>>(帶符號右移,)>>>(無符號右移)}

一、什麼是位移

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

語法格式:

number《位移的次數

二、位移運算子

按照平移的方向和填充數字的規則分為三種:《左移,>>右移,>>>無符號右移。

三、位移運算子的使用(運算規則)

程式設計中,位移運算子也是運算子的一種。

位移運算子組成的表示式也屬於算數表示式其值為算數值。

1、左移運算子(<<)

左移運算是將乙個二進位制位的運算元按指定移動的位數向左移位,移出位被丟棄,右邊的空位一律補0。

2、右移運算子(>>)

右移運算是將乙個二進位制位的運算元按指定移動的位數向右移動,移出位被丟棄,左邊移出的空位或者一律補0,或者補符號位,這由不同的機器而定。

在使用補碼作為機器數的機器中,正數的符號位為0,負數的符號位為1。

3、注意事項

在移位運算時,byte、short和char型別移位後的結果會變成int型別。

對於byte、short、char和int進行移位時,規定實際移動 的次數是移動次數和32的餘數,也就是移位33次和移位1次得到的結果相同。

移動long型的數值時,規定實際移動的次數是移動次數和64的餘數,也就是 移動66次和移動2次得到的結果相同。

四、簡單示例

1、左移運算子

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

例如: 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。

數學意義:

在數字沒有溢位的前提下,對於正數和負數,左移一位都相當於乘以2的1次方,左移n位就相當於乘以2的n次方。

2、右移運算子

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

語法格式:

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

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

計算過程:

11的二進位制形式為:0000 0000 0000 0000 0000 0000 0000 1011,然後把低位的最後兩個數字移出,因為該數字是正數,所以在高位補零。則得到的最終結果是0000 0000 0000 0000 0000 0000 0000 0010。轉換為十進位制是2。

3、無符號右移運算子

按二進位制形式把所有的數字向右移動對應位數,低位移出(捨棄),高位的空位補零。對於正數來說和帶符號右移相同,對於負數來說不同。

其他結構和》相似。

有的時候,你希望將乙個數的二進位制值向右或向左移位。執行左移時,在乙個數的二進位制形式中,所有位都向左移動由移位運算子右側的運算元指定的位數。 移位後在右邊留下的空位將由零來填充。右移位運算子的原理相似,只是朝相反的方向移位。然而,如果數是負數,那麼在左側填充的值就是1而不是0。兩個移位 運算子是》和<<,它們分別是右移位和左移位運算子。

除此之外,還有復合移位和賦值運算子<<=和》& gt;=。

二進位制 位運算 位移運算

二進位制.位運算.位移運算 二進位制是逢2進製的進製,0 1是基本算符。現代的電子計算機技術全部採用的是二進位制,因為它只是使用0 1兩個數字符號,非常簡單方便,易於用電子方式實現。計算機當中計算1 1步驟如下 找到1的補碼 正數的原碼 反碼 補碼相同 2計算機當中計算1 2步驟如下 1 2 1 2...

二進位制位運算子

二進位制位運算子用於直接對二進位制位進行計算,一共7個。i i 0 上面這行 的意思就是將i 不管是整數或小數 轉為32位整數。利用這一特性,可以寫乙個函式,將任意數值轉為32位整數。function toint32 x toint32 1.001 1 toint32 1.999 1 toint32...

二進位制中的運算子

二進位制中的運算子 與運算 兩者都為1則為1,否則為0 1 1 1,1 0 0,0 1 0,0 0 0 或運算 兩者都為0為0,否則為1 1 1 1,1 0 1,0 1 1,0 0 0 非運算 1取0 0 取1 1 0 0 1 1001 0110 異或運算 兩者相等為0,不等為1 1 1 0 1 0...