以下是利用标准库binary来进行编解码
编码
①使用bytes.Buffer来存储编码生成的串
②使用binary.Write来编码存储在①的buf中
package main import ( "bytes" "encoding/binary" "fmt" ) func main() { var pi float64 = 3.141592653589793 buf := new(bytes.Buffer) err := binary.Write(buf, binary.LittleEndian, pi) // 这里可以继续往buf里写, 都存在buf里 // binary.Write(buf, binary.LittleEndian, uint16(12345)) if err != nil { fmt.Println("binary.Read failed:", err) } fmt.Print(buf.Bytes()) // [24 45 68 84 251 33 9 64] }
解码
①使用bytes.NewReader/bytes.Buffer来存储要解码的ascii串
②使用binary.Read来解码
package main import ( "bytes" "encoding/binary" "fmt" ) func main() { var pi float64 bpi := []byte{0x18, 0x2d, 0x44, 0x54, 0xfb, 0x21, 0x09, 0x40} buf := bytes.NewReader(bpi) err := binary.Read(buf, binary.LittleEndian, &pi) // 这里可以继续读出来存在变量里, 这样就可以解码出来很多, 读的次序和变量类型要对 // binary.Read(buf, binary.LittlEndian, &v2) if err != nil { fmt.Println("binary.Read failed:", err) } fmt.Print(pi) // 3.141592653589793 }
Multi模式
-
解码
ing
-
编码
package main import ( "bytes" "encoding/binary" "fmt" ) func main() { buf := new(bytes.Buffer) var data = []interface{}{ uint16(61374), int8(-54), uint8(254), } for _, v := range data { err := binary.Write(buf, binary.LittleEndian, v) if err != nil { fmt.Println("binary.Write failed:", err) } } fmt.Printf("%x", buf.Bytes()) // beefcafe 这个是16进制串 // 这里转换为了16进制整数的串? }
转自:http://studygolang.com/articles/713