>> 是邏輯右移
>>> 是算術(shù)右移
邏輯右移和左移, 空位都是補(bǔ)0, 右移,空的高位補(bǔ)0, 左移,空的低位補(bǔ)0??梢哉J(rèn)為輸入都看作無符號數(shù)。
算術(shù)右移,高位補(bǔ)符號位,左移,低位補(bǔ)0。
但有一點(diǎn)要注意,高位補(bǔ)的是符號位。
所以如果一個(gè)32bit數(shù) 32‘hA0A0_FAFA;
如果把這個(gè)數(shù)值賦給一個(gè)int型變量, 符號位為1, 那么算術(shù)右移,高位是補(bǔ)1的;
如果這個(gè)數(shù)值是賦給了一個(gè)bit【31:0】變量,這是一個(gè)無符號數(shù),盡管最高位是1,但bit【31:0】的變量永遠(yuǎn)是一個(gè)非負(fù)數(shù),認(rèn)為符號位是0。所以,即使是>>>算術(shù)右移,高位仍然是補(bǔ)0的。
邏輯右移和左移的 第二個(gè)操作數(shù),不要是負(fù)數(shù),不然結(jié)果會(huì)是0.
算術(shù)左移的第二個(gè)操作數(shù),如果是負(fù)數(shù),結(jié)果是0.
算術(shù)右移的第二個(gè)操作數(shù),如果是負(fù)數(shù),如果第一個(gè)操作數(shù)是int型,有符號數(shù),結(jié)果不是0.
int a=‘hA0A0_FAFA
a = (a >>> -4)
結(jié)果是{28'hfff_ffff, 4'hA}, 4‘hA是高位的4bit A。
int a=‘h0A0A_FAFA
a = (a >>> -8)
結(jié)果是{24'h0, 8'h0A}, 8‘h0A是高位的8bit 0A。
不管怎么樣,保證第二個(gè)操作數(shù)不要為負(fù)數(shù),就不會(huì)出現(xiàn)意想不到的結(jié)果。同時(shí)記得第一個(gè)操作數(shù)的類型和符號位。