有没有更简单的方法可以使用FlatBuffers序列化[] [] byte?

时间:2019-09-21 18:04:38

标签: go flatbuffers

我希望使用FlatBuffers序列化[][]byte消息。鉴于无法嵌套FBS向量,看来这是可行的方法:

namespace msgfbs;

table SubmitMessage {
  nonces:[Nonce];
}

table Nonce {
  bytes:[ubyte];
}

现在要编写此结构,我最终编写了此函数:

func NewSubmitMessage(builder *fbs.Builder, nonces [][]byte) []byte {
    builder.Reset()

    nonceCount := len(nonces)

    // Convert nonces to byte vectors
    byteVectors := make([]fbs.UOffsetT, nonceCount)
    for i, nonce := range nonces {
        byteVectors[i] = builder.CreateByteVector(nonce)
    }

    // Create FBS Nonces
    noncesFbs := make([]fbs.UOffsetT, nonceCount)
    for i := range nonces {
        msgfbs.NonceStart(builder)
        msgfbs.NonceAddBytes(builder, byteVectors[i])
        noncesFbs[i] = msgfbs.NonceEnd(builder)
    }

    // Create vector of FBS Nonces
    msgfbs.SubmitMessageStartNoncesVector(builder, nonceCount)
    for i := nonceCount - 1; i >= 0; i-- {
        builder.PrependUOffsetT(noncesFbs[i])
    }
    noncesVector := builder.EndVector(nonceCount)

    // Create message
    msgfbs.SubmitMessageStart(builder)
    msgfbs.SubmitMessageAddNonces(builder, noncesVector)
    builder.Finish(msgfbs.SubmitMessageEnd(builder))
    builder.PrependByte(Submit)

    return builder.FinishedBytes()
}

我需要3个连续的for循环,最后包装我的消息。这是序列化[][]byte的最简单方法吗?有没有更有效的方法来达到相同的目的?

1 个答案:

答案 0 :(得分:1)

前两个for循环可以合并:您可以创建字节向量,然后创建包含该字节向量的表。您只是不能在开始/结束之间嵌套字节向量。

对于最后一个for循环,确实应该有一个辅助函数为您执行此操作(其他语言也存在)。如果Go中没有,请在FlatBuffers存储库中创建一个问题(或者更好的是PR)。