不帶正負號的右移運算子 (>>>)
更新:2007 年 11 月
將運算式的位元向右移位,不需保持正負號。
expression1 >>> expression2
引數
expression1
任何數值運算式。expression2
任何數值運算式。
備註
>>> 運算子利用 expression2 中所指定的位元數,將 expression1 的位元向右移。從左邊開始填入零。移出右邊界的數字會被捨棄。expression1 的資料型別決定本運算子傳回的資料型別。
>>> 運算子對 expression2 具有遮罩作用,以避免 expression1 移位太多。否則,若移位量超過 expression1 資料型別中的位元數,則所有原始位元都會移出而無法產生一般結果。為了確保每次移位至少都能留下一個原始位元,移位運算子使用以下公式計算實際的移位量:以 expression1 中的位元數減一,做為 expression2 的遮罩 (使用位元 AND 運算子)。
範例
例如:
var temp
temp = -14 >>> 2
變數 temp 的值為 1073741820,也就是 -14 (二進位為 11111111 11111111 11111111 11110010) 向右移兩位元就等於 1073741820 (二進位為 00111111 11111111 11111111 11111100)。
若要暸解遮罩的作業方式,請參考以下範例。
var x : byte = 15;
// A byte stores 8 bits.
// The bits stored in x are 00001111
var y : byte = x >>> 10;
// Actual shift is 10 & (8-1) = 2
// The bits stored in y are 00000011
// The value of y is 3
print(y); // Prints 3