欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java任意長度byte數(shù)組轉(zhuǎn)換為int數(shù)組的方法

 更新時(shí)間:2020年07月26日 15:27:22   作者:zhuimengfb  
這篇文章主要給大家介紹了關(guān)于Java任意長度byte數(shù)組轉(zhuǎn)換為int數(shù)組的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者使用Java具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧

前言

嗯。最近工程上遇到一個(gè)byte數(shù)組轉(zhuǎn)換為int的問題,解決過程中遇到了幾個(gè)坑,經(jīng)過各種查資料終于還是解決了。撒花。

Java的位運(yùn)算以及byte數(shù)組與其他類型數(shù)據(jù)的轉(zhuǎn)換比c/c++感覺麻煩一些。這里簡(jiǎn)單說明一下byte數(shù)組和int的轉(zhuǎn)換吧。

總所周知,int類型數(shù)據(jù)在Java中占據(jù)32 bit,byte占據(jù)8 bit,這樣的話,正常情況下4個(gè)byte可以轉(zhuǎn)換成一個(gè)int類型數(shù)據(jù)。

當(dāng)然,不正常情況下,3個(gè)byte或者2個(gè)byte甚至1個(gè)byte都可以轉(zhuǎn)換為int數(shù)據(jù),只需要高位補(bǔ)上就行。

嗯,坑來了。由于Java中int類型是有符號(hào)的,最高位為符號(hào)位,為0的話表示正數(shù),為1的話表示負(fù)數(shù)。

以四位byte數(shù)組為例,要拼接成一個(gè)32 bit的int數(shù)據(jù)的話,只需要將四個(gè)byte按順序連接起來就行,這樣的話,就需要對(duì)四個(gè)byte進(jìn)行移位操作。

第一位左移24位,第二位左移16位,第三位左移8位,第四位不動(dòng)。。然后進(jìn)行或運(yùn)算。。

嗯,看起來好像完美。。。然而之前說過Java是有符號(hào)的,對(duì)于后三個(gè)byte,如果是負(fù)數(shù)的話,則高位都是1,這樣高位的或運(yùn)算將失效,前面的byte數(shù)據(jù)也就沒有意義。

因此,對(duì)于后三個(gè)byte數(shù)據(jù),進(jìn)行移位操作前需要和0XFF進(jìn)行與運(yùn)算,消除高24位。

代碼如下

public int bytesToInt(byte[] bytes){
  return bytes[0]<<24|(bytes[1]&0xff)<<16|(bytes[2]&0xff)<<8|(bytes[3]&0xff);
 }

對(duì)于不正常的情況,比如3個(gè)byte轉(zhuǎn)換為int,則第一個(gè)左移16位,第二位與0xff后左移8位,第三位與0xff,然后進(jìn)行或運(yùn)算即可。

同理可運(yùn)用于2個(gè)byte。

對(duì)于1個(gè)byte,直接強(qiáng)制轉(zhuǎn)換為int即可。

嗯。。大概就是這樣,第一位移位,之后的分別和0xff相與后再移位,最后進(jìn)行或運(yùn)算即可。

后來,閑著無聊,如果一個(gè)byte數(shù)組超過4位后,怎么辦?當(dāng)然返回一個(gè)int數(shù)組就行啦,反正4位byte轉(zhuǎn)換成1個(gè)int,看著辦就行。

public int[] bytesToInts(byte[] bytes){
  int bytesLength=bytes.length;
  int[] ints=new int[bytesLength%4==0? bytesLength/4:bytesLength/4+1];
  int lengthFlag=4;
  while (lengthFlag<=bytesLength){
   ints[lengthFlag/4-1]=(bytes[lengthFlag-4]<<24)|(bytes[lengthFlag-3]&0xff)<<16|
     (bytes[lengthFlag-2]&0xff)<<8|(bytes[lengthFlag-1]&0xff);
   lengthFlag+=4;
  }
  for (int i=0;i<bytesLength+4-lengthFlag;i++){
   if (i==0) ints[lengthFlag/4-1]|=bytes[lengthFlag-4+i]<<8*(bytesLength+4-lengthFlag-i-1);
   else ints[lengthFlag/4-1]|=(bytes[lengthFlag-4+i]&0xff)<<8*(bytesLength+4-lengthFlag-i-1);
  }
  return ints;
 }

嗯。。有空再來寫寫Java的bit提取。。

總結(jié)

到此這篇關(guān)于Java任意長度byte數(shù)組轉(zhuǎn)換為int數(shù)組的文章就介紹到這了,更多相關(guān)Java byte數(shù)組轉(zhuǎn)換為int數(shù)組內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解Java實(shí)現(xiàn)設(shè)計(jì)模式之責(zé)任鏈模式

    詳解Java實(shí)現(xiàn)設(shè)計(jì)模式之責(zé)任鏈模式

    責(zé)任鏈模式是一種行為設(shè)計(jì)模式,允許你將請(qǐng)求沿著處理鏈發(fā)送,然后處理者都可對(duì)其進(jìn)行處理,完成后可以再將其傳遞給下一個(gè)處理者。下面將會(huì)舉例說明什么是責(zé)任鏈模式,責(zé)任鏈模式該如何使用
    2021-06-06
  • spring boot如何指定啟動(dòng)端口

    spring boot如何指定啟動(dòng)端口

    這篇文章主要介紹了spring boot如何指定啟動(dòng)端口,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-12-12
  • Spring的異常重試框架Spring Retry簡(jiǎn)單配置操作

    Spring的異常重試框架Spring Retry簡(jiǎn)單配置操作

    這篇文章主要介紹了Spring的異常重試框架Spring Retry簡(jiǎn)單配置操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • 如何基于springboot-admin實(shí)現(xiàn)后臺(tái)監(jiān)控

    如何基于springboot-admin實(shí)現(xiàn)后臺(tái)監(jiān)控

    這篇文章主要介紹了如何基于springboot-admin實(shí)現(xiàn)后臺(tái)監(jiān)控,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • Java常用的八種排序算法及代碼實(shí)現(xiàn)+圖解

    Java常用的八種排序算法及代碼實(shí)現(xiàn)+圖解

    這篇文章主要介紹了Java常用的八種排序算法及代碼實(shí)現(xiàn),在Java的時(shí)候,對(duì)于排序的應(yīng)用需要熟練的掌握,這樣才能夠確保Java學(xué)習(xí)時(shí)候能夠有扎實(shí)的基礎(chǔ)能力。那Java有哪些排序算法呢?本文小編就來詳細(xì)說說Java經(jīng)典的8種排序算法,需要的朋友可以參考一下
    2021-12-12
  • JAVA十大排序算法之選擇排序詳解

    JAVA十大排序算法之選擇排序詳解

    這篇文章主要介紹了java中的選擇排序,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-08-08
  • 編輯器Ueditor和SpringBoot 的整合方法

    編輯器Ueditor和SpringBoot 的整合方法

    本文通過實(shí)例代碼給大家介紹了編輯器Ueditor和SpringBoot 的整合方法,需要的朋友參考下吧
    2017-08-08
  • 分析Java設(shè)計(jì)模式之組合模式

    分析Java設(shè)計(jì)模式之組合模式

    組合模式是一種對(duì)象的行為模式。將對(duì)象組合成樹形結(jié)構(gòu)以表示“部分-整體”的層次結(jié)構(gòu)。組合模式使得用戶對(duì)單個(gè)對(duì)象和組合對(duì)象的使用具有一致性。它的本質(zhì)是統(tǒng)一葉子對(duì)象和組合對(duì)象。它的目的是讓客戶端不再區(qū)分操作的是組合對(duì)象還是葉子對(duì)象,而是以一個(gè)統(tǒng)一的方式來操作
    2021-06-06
  • logback自定義日志與Nacos日志沖突問題

    logback自定義日志與Nacos日志沖突問題

    這篇文章主要介紹了logback自定義日志與Nacos日志沖突問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • 詳談spring boot中幾種常見的依賴注入問題

    詳談spring boot中幾種常見的依賴注入問題

    這篇文章主要介紹了spring boot中幾種常見的依賴注入問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-09-09

最新評(píng)論