分享
golang -- 网络字节编解码(2)
flyking · · 12701 次点击 · · 开始浏览这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。
以下是利用标准库binary来进行编解码
解码
1使用bytes.NewReader/bytes.Buffer来存储要解码的ascii串
2使用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 }
编码
1使用bytes.Buffer来存储编码生成的串
2使用binary.Write来编码存储在1的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] }
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进制整数的串? }
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信12701 次点击
添加一条新回复
(您需要 后才能回复 没有账号 ?)
- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
以下是利用标准库binary来进行编解码
解码
1使用bytes.NewReader/bytes.Buffer来存储要解码的ascii串
2使用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 }
编码
1使用bytes.Buffer来存储编码生成的串
2使用binary.Write来编码存储在1的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] }
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进制整数的串? }