我就廢話不多說了,大家還是直接看代碼吧~
//isSymbol表示有無符號 func BytesToInt(b []byte, isSymbol bool) (int, error){ if isSymbol { return bytesToIntS(b) } return bytesToIntU(b) } //字節數(大端)組轉成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!") } } //字節數(大端)組轉成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!") } } //整形轉換成字節 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轉換
使用場景:
在tcp協議傳輸中,為了防止粘包,需要先發送消息頭,即先發送數據長度,在根據長度write真正的數據,然e,由于網絡傳輸都是字節流,怎么將整型轉為字節流呢?
只需四步:
轉換----int轉int64
申請----申請一個字節緩沖
寫入----按照二進制,向緩沖寫入數據
取出----以字節流從緩沖中取出
func IntToBytes(n int)[]byte{ data:=int64(n)//數據類型轉換 bytebuffer:=bytes.NewBuffer([]byte{})//字節集合 binary.Write(bytebuffer,binary.BigEndian,data)//按照二進制寫入字節 return bytebuffer.Bytes()//返回字節結合 }
解碼同樣需兩步:
1.創建一個以字節流為內容的buffer()
2.從buf緩沖讀取binary編碼的數據并賦給data
func BytesToInt(bs []byte)int{ bytebuffer:=bytes.NewBuffer(bs) //根據二進制寫入二進制結合 var data int64 binary.Read(bytebuffer,binary.BigEndian,data) //解碼 return int(data) }
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。