对码当歌,猿生几何?

golang -- 网络字节编解码(2)

以下是利用标准库binary来进行编解码

 

  • 解码 
    ①使用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
    }

     

     

  • 编码 
    ①使用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]
    
    }

     



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进制整数的串?
    }

阅读更多