dswu26846 2016-03-25 19:29
浏览 453
已采纳

golang有效的二进制编码

I have a program that sends udp packets. a packet datagram is represented by the following struct (notice that the size of the packet isn't fixed):

type packet struct {
    dataLength uint16
    id [8]byte
    pairity, shards, flags byte
    blob []byte // length defined by dataLength 
}

I used encoding/binary package to do serialization/deserialization but it wasn't efficient enough (used pprof). it wasted alot of CPU time and I couldn't utilize the whole network speed because of that.

for example, consider the following code:

packet := packet{
    dataLength: 4,
    id: [8]byte{1,2,3,4,5,6,7,8},
    pairity: 10,
    shards: 50,
    flags: 200,
    blob: []byte{1,2,3,4},
}
bufToSendOverNetwork := packet.ToBytes()

What is the most efficient way to do this operation (and also the .FromBytes operation)

  • 写回答

1条回答 默认 最新

  • duanmianhong4893 2016-03-25 19:34
    关注

    encoding/binary.Write uses reflection, so it will be slower than anything that manually constructs the buffer. Below is an example of such a function:

    import (
        "encoding/binary"
    )
    
    func (p *packet) ToBytes() []byte {
        buff := make([]byte, 2 + 8 + 3 + len(p.blob))
    
        binary.BigEndian.PutUint16(buff[:2], p.dataLength)
        copy(buff[2:10], p.id[:])
        buff[10] = p.pairity
        buff[11] = p.shards
        buff[12] = p.flags
        copy(buff[13:], p.blob)
    
        return buff
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 Stata链式中介效应代码修改
  • ¥15 latex投稿显示click download
  • ¥15 请问读取环境变量文件失败是什么原因?
  • ¥15 在若依框架下实现人脸识别
  • ¥15 网络科学导论,网络控制
  • ¥100 安卓tv程序连接SQLSERVER2008问题
  • ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错