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ù)計算,接下來我們就給大家詳細介紹一下sync.singleflight如何解決熱點緩存穿透問題2023-07-07

