亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

[轉(zhuǎn)]java中char,byte,short的移位操作

系統(tǒng) 2080 0

在Think in Java中有這么一段話“ 對char,byte或者short進行移位處理,那么在移位進行之前,它們會自動轉(zhuǎn)換成一個int。只有右側(cè)的5個低位才會有用。這樣可防止我們在一個int數(shù)里移動不切實際的位數(shù)。若對一個long值進行處理,最后得到的結果也是long。此時只會用到右側(cè)的6個低位,防止移動超過long值里現(xiàn)成的位數(shù) 。”

?

對上面那段話的理解是:移位操作符操作的運算對象是二進制的“位”,int類型是32位也就是2的5次冪 !如果移32位以上,那么原來的數(shù)的信息會全部丟失,這樣也就沒有什么意義了!所以上面的“只有右側(cè)的5個低位才會有用”說的是: 移位操作符右端的那個數(shù)(化成二進制)的低5位才有用,即 ? X < <y; ?? 是指y的低5位才有用,即不能大于32 。 而對于long型也是同樣的道理!

因此,如果對一個int 型,進行移位,X < <y; 當y小于32時,移位后的結果一般都在我們的預料當中;而如果y大于32時, 由于移位超出了int所能表示的范圍,這時就先把y化成二進制數(shù),然后取該二進制數(shù)右端的低5位(相當于&11111或者是除32得到的余數(shù)),再把這5位化成十進制,此時的這個十進制就是要對X移動的位數(shù)。

例如:????????

                                     int i = 1245;
		String s = Integer.toBinaryString(i);
		int y1 = i>>2;
		String s1 = Integer.toBinaryString(y1);
		int y2 = i>>34;
		String s2 = Integer.toBinaryString(y2);
		System.out.println(i + "->" + s + "  " + y1 + "->" + s1 + "  " + y2 + "->" + s2);
  
語句“ int y2 = i>>34;”的執(zhí)行過程是:先把i化成二進制數(shù):10011011101

?執(zhí)行結果:

    1245->10011011101  311->100110111  311->100110111
  

?

執(zhí)行語句 i>> 34?? 對i右移34位時,先把34化成二進制:100010,對該二進制數(shù)取右邊5位,即00010,化成十進制數(shù)為2,所以實際上是對i右移兩位。現(xiàn)在,結果是:100110111

?

?

long型數(shù)據(jù)移位時一樣的道理,long型一共64位,如果移動的位數(shù)超過64(2^8)就沒有意義了,所以在移位前判斷移動的位數(shù)是否大于64,如果大于了64則取該位數(shù)的低8位(除以64得到的余數(shù)),再移位,否則直接移位。

移位運算符和按位運算符一樣,同屬于位運算符,因此移位運算符的位指的也是二進制位。它包括以下幾種:
左移位(<<):將操作符左側(cè)的操作數(shù)向左移動操作符右側(cè)指定的位數(shù)。移動的規(guī)則是在二進制的低位補0。

  1. 有符號右移位(>>):將操作符左側(cè)的操作數(shù)向右移動操作符右側(cè)指定的位數(shù)。移動的規(guī)則是,如果被操作數(shù)的符號為正,則在二進制的高位補0;如果被操作數(shù)的符號為負,則在二進制的高位補1。
  2. 無符號右移位(>>>):將操作符左側(cè)的操作數(shù)向右移動操作符右側(cè)指定的位數(shù)。移動的規(guī)則是,無論被操作數(shù)的符號是正是負,都在二進制位的高位補0。


注意,移位運算符不存在“無符號左移位(<<<)”一說。與按位運算符一樣, 移位運算符可以用于byte、short、int、long等整數(shù)類型,和字符串類型char,但是不能用于浮點數(shù)類型float、double ;當然,在Java5.0及以上版本中,移位運算符還可用于byte、short、int、long、char對應的包裝器類。我們可以參照按位運算符的示例寫一個測試程序來驗證,這里就不再舉例了。
與按位運算符不同的是,移位運算符不存在短路不短路的問題。
寫到這里就不得不提及一個在面試題中經(jīng)常被考到的題目:

引用
請用最有效率的方法計算出2乘以8等于幾?


這里所謂的最有效率,實際上就是通過最少、最簡單的運算得出想要的結果,而移位是計算機中相當基礎的運算了,用它來實現(xiàn)準沒錯了。 左移位“<<”把被操作數(shù)每向左移動一位,效果等同于將被操作數(shù)乘以2,同理,無符號右移位">>>"把被操作數(shù)每向右移動一位,效果等同于將被操作數(shù)除以2, 而2*8=(2*2*2*2),就是把2向左移位3次。因此最有效率的計算2乘以8的方法就是“2<<3”。

最后,我們再來考慮一種情況,當要移位的位數(shù)大于被操作數(shù)對應數(shù)據(jù)類型所能表示的最大位數(shù)時,結果會是怎樣呢?比如,1<<35=?呢?
這里就涉及到移位運算的另外一些規(guī)則:

  1. byte、short、char在做移位運算之前,會被自動轉(zhuǎn)換為int類型,然后再進行運算。
  2. byte、short、int、char類型的數(shù)據(jù)經(jīng)過移位運算后結果都為int型。
  3. long經(jīng)過移位運算后結果為long型。
  4. 在左移位(<<)運算時,如果要移位的位數(shù)大于被操作數(shù)對應數(shù)據(jù)類型所能表示的最大位數(shù),那么先將要求移位數(shù)對該類型所能表示的最大位數(shù)求余后,再將被操作數(shù)移位所得余數(shù)對應的數(shù)值,效果不變。比如1<<35=1<<(35%32)=1<<3=8。
  5. 對于有符號右移位(>>)運算和無符號右移位(>>>)運算,當要移位的位數(shù)大于被操作數(shù)對應數(shù)據(jù)類型所能表示的最大位數(shù)時,那么先將要求移位數(shù)對該類型所能表示的最大位數(shù)求余后,再將被操作數(shù)移位所得余數(shù)對應的數(shù)值,效果不變。。比如100>>35=100>>(35%32)=100>>3=12。


下面的測試代碼驗證了以上的規(guī)律:

Java代碼 ? 復制代碼
  1. public ? abstract ? class ?Test?{ ??
  2. ???? public ? static ? void ?main(String[]?args)?{ ??
  3. ????????System.out.println( "1?<<?3?=?" ?+?( 1 ?<<? 3 )); ??
  4. ????????System.out.println( "(byte)?1?<<?35?=?" ?+?(( byte )? 1 ?<<?( 32 ?+? 3 ))); ??
  5. ????????System.out.println( "(short)?1?<<?35?=?" ?+?(( short )? 1 ?<<?( 32 ?+? 3 ))); ??
  6. ????????System.out.println( "(char)?1?<<?35?=?" ?+?(( char )? 1 ?<<?( 32 ?+? 3 ))); ??
  7. ????????System.out.println( "1?<<?35?=?" ?+?( 1 ?<<?( 32 ?+? 3 ))); ??
  8. ????????System.out.println( "1L?<<?67?=?" ?+?(1L?<<?( 64 ?+? 3 ))); ??
  9. ???????? //?此處需要Java5.0及以上版本支持 ? ??
  10. ????????System.out.println( "new?Integer(1)?<<?3?=?" ?+?( new ?Integer( 1 )?<<? 3 )); ??
  11. ????????System.out.println( "10000?>>?3?=?" ?+?( 10000 ?>>? 3 )); ??
  12. ????????System.out.println( "10000?>>?35?=?" ?+?( 10000 ?>>?( 32 ?+? 3 ))); ??
  13. ????????System.out.println( "10000L?>>>?67?=?" ?+?(10000L?>>>?( 64 ?+? 3 ))); ??
  14. ????} ??
  15. }??


運行結果:

  1. 1 << 3 = 8
  2. (byte) 1 << 35 = 8
  3. (short) 1 << 35 = 8
  4. (char) 1 << 35 = 8
  5. 1 << 35 = 8
  6. 1L << 67 = 8
  7. new Integer(1) << 3 = 8
  8. 10000 >> 3 = 1250
  9. 10000 >> 35 = 1250
  10. 10000L >>> 67 = 1250

轉(zhuǎn)自: http://blog.csdn.net/chattie/archive/2009/03/27/4029922.aspx

[轉(zhuǎn)]java中char,byte,short的移位操作


更多文章、技術交流、商務合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 青青久草在线视频 | 精久久 | 欧美日韩国产一区二区 | 在线播放波多野结衣 | 99re在线| 久久精品国产精品亚洲红杏 | 欧美日韩亚洲国内综合网香蕉 | 99婷婷久久精品国产一区二区 | 国语性猛交xxxx乱大交 | 91精品啪在线观看国产色 | 一级作爱视频免费观看 | 欧美一级爆毛片 | 毛色毛片免费观看 | 九色精品视频在线观看 | 99久久精品久久久久久婷婷 | 99精品国产久热在线观看66 | 欧美中文字幕在线视频 | 欧美日韩一区二区不卡三区 | 国产精品婷婷久久爽一下 | 中文字幕亚洲综合久久男男 | 久视频免费精品6 | 亚洲综合日韩精品欧美综合区 | 国产视频福利一区 | 国产人成精品综合欧美成人 | 国产成人一区二区三区视频免费蜜 | 美女久久久久久久久久久 | 国产精品久久亚洲不卡4k岛国 | 成人短视频在线观看视频 | 色网站在线看 | 99久久免费国内精品 | 久综合网 | 国产一区曰韩二区欧美三区 | 亚洲一区二区三区久久久久 | 成人国产精品一级毛片视频 | 国产精品免费久久久久影院 | 欧美成人交tv免费观看 | 99精品国产高清自在线看超 | 香蕉视频在线观看网站 | 国产精品欧美亚洲 | 91综合网| 久久91精品国产91久久 |