Java任意長度byte數(shù)組轉(zhuǎn)換為int數(shù)組的方法
前言
嗯。最近工程上遇到一個(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é)任鏈模式
責(zé)任鏈模式是一種行為設(shè)計(jì)模式,允許你將請(qǐng)求沿著處理鏈發(fā)送,然后處理者都可對(duì)其進(jìn)行處理,完成后可以再將其傳遞給下一個(gè)處理者。下面將會(huì)舉例說明什么是責(zé)任鏈模式,責(zé)任鏈模式該如何使用2021-06-06Spring的異常重試框架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)控,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-04-04Java常用的八種排序算法及代碼實(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