golang實現(xiàn)整型和字節(jié)數(shù)組之間的轉(zhuǎn)換操作
我就廢話不多說了,大家還是直接看代碼吧~
//isSymbol表示有無符號 func BytesToInt(b []byte, isSymbol bool) (int, error){ if isSymbol { return bytesToIntS(b) } return bytesToIntU(b) } //字節(jié)數(shù)(大端)組轉(zhuǎn)成int(無符號的) func bytesToIntU(b []byte) (int, error) { if len(b) == 3 { b = append([]byte{0},b...) } bytesBuffer := bytes.NewBuffer(b) switch len(b) { case 1: var tmp uint8 err := binary.Read(bytesBuffer, binary.BigEndian, &tmp) return int(tmp), err case 2: var tmp uint16 err := binary.Read(bytesBuffer, binary.BigEndian, &tmp) return int(tmp), err case 4: var tmp uint32 err := binary.Read(bytesBuffer, binary.BigEndian, &tmp) return int(tmp), err default: return 0,fmt.Errorf("%s", "BytesToInt bytes lenth is invaild!") } } //字節(jié)數(shù)(大端)組轉(zhuǎn)成int(有符號) func bytesToIntS(b []byte) (int, error) { if len(b) == 3 { b = append([]byte{0},b...) } bytesBuffer := bytes.NewBuffer(b) switch len(b) { case 1: var tmp int8 err := binary.Read(bytesBuffer, binary.BigEndian, &tmp) return int(tmp), err case 2: var tmp int16 err := binary.Read(bytesBuffer, binary.BigEndian, &tmp) return int(tmp), err case 4: var tmp int32 err := binary.Read(bytesBuffer, binary.BigEndian, &tmp) return int(tmp), err default: return 0,fmt.Errorf("%s", "BytesToInt bytes lenth is invaild!") } } //整形轉(zhuǎn)換成字節(jié) func IntToBytes(n int,b byte) ([]byte,error) { switch b { case 1: tmp := int8(n) bytesBuffer := bytes.NewBuffer([]byte{}) binary.Write(bytesBuffer, binary.BigEndian, &tmp) return bytesBuffer.Bytes(),nil case 2: tmp := int16(n) bytesBuffer := bytes.NewBuffer([]byte{}) binary.Write(bytesBuffer, binary.BigEndian, &tmp) return bytesBuffer.Bytes(),nil case 3,4: tmp := int32(n) bytesBuffer := bytes.NewBuffer([]byte{}) binary.Write(bytesBuffer, binary.BigEndian, &tmp) return bytesBuffer.Bytes(),nil } return nil,fmt.Errorf("IntToBytes b param is invaild") }
補充:golang整型,float與byte轉(zhuǎn)換
使用場景:
在tcp協(xié)議傳輸中,為了防止粘包,需要先發(fā)送消息頭,即先發(fā)送數(shù)據(jù)長度,在根據(jù)長度write真正的數(shù)據(jù),然e,由于網(wǎng)絡(luò)傳輸都是字節(jié)流,怎么將整型轉(zhuǎn)為字節(jié)流呢?
只需四步:
轉(zhuǎn)換----int轉(zhuǎn)int64
申請----申請一個字節(jié)緩沖
寫入----按照二進制,向緩沖寫入數(shù)據(jù)
取出----以字節(jié)流從緩沖中取出
func IntToBytes(n int)[]byte{ data:=int64(n)//數(shù)據(jù)類型轉(zhuǎn)換 bytebuffer:=bytes.NewBuffer([]byte{})//字節(jié)集合 binary.Write(bytebuffer,binary.BigEndian,data)//按照二進制寫入字節(jié) return bytebuffer.Bytes()//返回字節(jié)結(jié)合 }
解碼同樣需兩步:
1.創(chuàng)建一個以字節(jié)流為內(nèi)容的buffer()
2.從buf緩沖讀取binary編碼的數(shù)據(jù)并賦給data
func BytesToInt(bs []byte)int{ bytebuffer:=bytes.NewBuffer(bs) //根據(jù)二進制寫入二進制結(jié)合 var data int64 binary.Read(bytebuffer,binary.BigEndian,&data) //解碼 return int(data) }
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
golang使用sync.singleflight解決熱點緩存穿透問題
在go的sync包中,有一個singleflight包,里面有一個?singleflight.go文件,代碼加注釋,一共200行出頭,通過?singleflight可以很容易實現(xiàn)緩存和去重的效果,避免重復(fù)計算,接下來我們就給大家詳細(xì)介紹一下sync.singleflight如何解決熱點緩存穿透問題2023-07-07