我就廢話不多說(shuō)了,大家還是直接看代碼吧~
//isSymbol表示有無(wú)符號(hào)
func BytesToInt(b []byte, isSymbol bool) (int, error){
if isSymbol {
return bytesToIntS(b)
}
return bytesToIntU(b)
}
//字節(jié)數(shù)(大端)組轉(zhuǎn)成int(無(wú)符號(hào)的)
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(有符號(hào))
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")
}
補(bǔ)充:golang整型,float與byte轉(zhuǎn)換
使用場(chǎng)景:
在tcp協(xié)議傳輸中,為了防止粘包,需要先發(fā)送消息頭,即先發(fā)送數(shù)據(jù)長(zhǎng)度,在根據(jù)長(zhǎng)度write真正的數(shù)據(jù),然e,由于網(wǎng)絡(luò)傳輸都是字節(jié)流,怎么將整型轉(zhuǎn)為字節(jié)流呢?
只需四步:
轉(zhuǎn)換----int轉(zhuǎn)int64
申請(qǐng)----申請(qǐng)一個(gè)字節(jié)緩沖
寫入----按照二進(jìn)制,向緩沖寫入數(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)//按照二進(jìn)制寫入字節(jié)
return bytebuffer.Bytes()//返回字節(jié)結(jié)合
}
解碼同樣需兩步:
1.創(chuàng)建一個(gè)以字節(jié)流為內(nèi)容的buffer()
2.從buf緩沖讀取binary編碼的數(shù)據(jù)并賦給data
func BytesToInt(bs []byte)int{
bytebuffer:=bytes.NewBuffer(bs) //根據(jù)二進(jìn)制寫入二進(jìn)制結(jié)合
var data int64
binary.Read(bytebuffer,binary.BigEndian,data) //解碼
return int(data)
}
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
您可能感興趣的文章:- golang json數(shù)組拼接的實(shí)例
- Golang 如何判斷數(shù)組某個(gè)元素是否存在(isset)
- golang移除數(shù)組中重復(fù)的元素操作
- golang將切片或數(shù)組根據(jù)某個(gè)字段進(jìn)行分組操作
- golang數(shù)組-----尋找數(shù)組中缺失的整數(shù)方法
- golang求連續(xù)子數(shù)組的最大和實(shí)例
- Golang 如何判斷數(shù)組某個(gè)元素是否存在 (isset)