我希望使用 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/