自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Java的位移運算巧方法

開發(fā) 后端
Java對移位運算"a <<||>> b"的處理,首先做 b mod 32||64運算, 如果a是int型,取mod 32,如果a是double型,取mod 64,然后再使用上面提到的通用移位運算規(guī)則進(jìn)行移位。

左移操作: x << n

x可以是byte, short, char, int, long基本類型, n(位移量)只能是int型

編譯器的執(zhí)行步驟:

1) 如果x是byte, short, char類型, 則將x提升為int;

2) 如果x是byte, short, char, int類型, 則n被重新賦值(過程是:取n的補(bǔ)碼的低5位再轉(zhuǎn)成十進(jìn)制的int值,相當(dāng)對n取32模: n=n%32);

如果x是long型, 則n被重新賦值(過程是:取n的補(bǔ)碼的低6位再轉(zhuǎn)成十進(jìn)制的int值,相當(dāng)對n取64模: n=n%64);

(因為int類型為4個字節(jié),即32位,移動32位將沒有任何意義.對于long則是模64)

3) 對x左移n個位數(shù), 整個表達(dá)式產(chǎn)生一個新值(x的值不變);

<<是左移符號,列x<<1,就是x的內(nèi)容左移一位(x的內(nèi)容并不改變)

>>是帶符號位的右移符號,x>>1就是x的內(nèi)容右移一位,如果開頭是1則補(bǔ)1,是0責(zé)補(bǔ)0,(x的內(nèi)容并不改變).

>>>是不帶符號位的右移,x>>>1就是x的內(nèi)容右移一位,開頭補(bǔ)0(x的內(nèi)容并不改變)

補(bǔ)充說明:

Java代碼

  1. // 左移: 向左移動,右邊補(bǔ)0   
  2.   for (int i = 0;i < 8 ;i++)   
  3.   System.out.print( (1 << i) + " "); 

output

1 2 4 8 16 32 64 128

  1. // 右移: 向右移動,如果符號位(int型為32位)為0,左邊補(bǔ)0,符號位為1,左邊補(bǔ)1   
  2.   // 符號位為1的右移   
  3.   for (int i = 0;i < 8 ;i++)   
  4.   System.out.print( Integer.toHexString(0x40000000 >> i) + " "); 

output

40000000 20000000 10000000 8000000 4000000 2000000 1000000 800000

  1.  // 符號位為1的右移   
  2.   // 最高4位為1000, 右移1位,變成1100也就是c,   
  3.   for (int i = 0;i < 8 ;i++)   
  4.   System.out.print( Integer.toHexString(0x80000000 >> i) + " "); 

output

80000000 c0000000 e0000000 f0000000 f8000000 fc000000 fe000000 ff000000

上面的通用法則沒有錯,但是有一個限制,對int型,移位的位數(shù)不超過32,對long型,移位的位數(shù)不超過64?,F(xiàn)在進(jìn)行如下測試:

Java代碼

  1. System.out.println(Integer.toHexString(0x80000000 >> 31));   
  2.   // output: ffffffff   
  3.   System.out.println(Integer.toHexString(0x80000000 >> 32));   
  4.   // output: 80000000 

0x80000000在右移31位后,每個位都成了1(也就是-1),按照這個想法,右移32位理所當(dāng)然的還是-1,可是右移32位后,得到的結(jié)果卻又這個數(shù)本身。

通過對int,long類型數(shù)據(jù)左右移進(jìn)行測試,發(fā)現(xiàn):

Java對移位運算"a <<||>> b"的處理,首先做 b mod 32||64運算, 如果a是int型,取mod 32,如果a是double型,取mod 64,然后再使用上面提到的通用移位運算規(guī)則進(jìn)行移位。

到這里,就可以理解為什么在BitSet類中是

  1. 1L << bitIndex 

這條語句,因為熟悉jdk的Programer知道,再寫 1L << (bitIndex % 64) 對jdk來說是多余的。

原文連接:http://blog.csdn.net/hopezhangbo/article/details/7348740

【編輯推薦】

  1.  Java7的一個新類JLayer:裝飾的Swing組件
  2. 關(guān)于Java中內(nèi)存溢出的解決辦法
  3. Java中的面向?qū)ο筇匦?/a>
  4. 探究Java初始化的過程
  5. Java集合框架的知識總結(jié)
責(zé)任編輯:林師授 來源: hopezhangbo的博客
相關(guān)推薦

2009-12-24 16:20:19

Linux破解PHP

2010-07-29 09:18:40

2011-05-05 09:27:07

傳真機(jī)CCD

2010-12-01 11:29:11

職場

2012-05-08 10:22:47

Windows系統(tǒng)硬件

2015-08-14 09:37:44

Java字符串基本運算

2009-08-16 16:11:05

2011-04-12 16:01:04

MySQL查詢編寫

2010-09-17 13:45:40

JVM termina

2016-02-15 09:25:00

R語言運算效率大數(shù)據(jù)

2014-09-01 15:33:24

Lua語言基礎(chǔ)table構(gòu)造方式

2009-07-16 13:30:12

resultMapgroupBy屬性

2010-01-13 15:46:21

2009-01-05 09:47:17

2023-10-29 09:11:03

DSL語法

2015-10-19 11:05:33

綜合布線數(shù)據(jù)中心

2025-02-07 10:54:07

2013-08-02 09:34:11

平臺即服務(wù)PaaSPaaS平臺

2011-03-03 10:31:42

數(shù)據(jù)庫

2010-11-19 15:44:04

IT跳槽
點贊
收藏

51CTO技術(shù)棧公眾號