go - 有没有更简单的方法来使用 FlatBuffers 序列化 [][]byte?

标签 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 的最简单方法吗?有没有更有效的方法来实现同样的目标?

最佳答案

可以合并前 2 个 for 循环:您可以创建字节向量,然后创建包含它的表。您不能在 Start/End 之间嵌套字节向量。

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

关于go - 有没有更简单的方法来使用 FlatBuffers 序列化 [][]byte?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58042846/

相关文章:

file - Golang 中的 bufio.NewScanner 是否读取内存中的整个文件而不是每个文件一行?

macos - 使用Golang访问数据库时出现架构错误

函数参数中的多态性

Rust Flatbuffers 索引超出范围错误

go - 使用 golang 时无法从 cgo 例程中获取带有核心文件的堆栈跟踪

java - 使用 Marathon/Mesos 的 Prometheus 动态端口服务发现

c++ - Protobuf vs Flatbuffers vs Cap'n proto哪个更快?

c - 如何在 FlatBuffers 架构文件中声明指针类型?

c++ - 缓冲区大小每次增加

c++ - FlatBuffers 是否以某种方式避免了严格的别名?